校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > MySQL隱式類型轉換導致索引失效的解決

MySQL隱式類型轉換導致索引失效的解決

熱門標簽:云南電商智能外呼系統價格 400電話可以辦理嗎 大眾點評星級酒店地圖標注 臨清電話機器人 拉卡拉外呼系統 高清地圖標注道路 話務外呼系統怎么樣 外東北地圖標注 智能外呼系統復位

問題

在工作中發現,有一個接口只執行一條SQL查詢語句,并且SQL明明使用了主鍵列,但是速度很慢。
在MySQL中EXPLAINN后發現,執行時并沒有使用主鍵索引,而是進行了全表掃描。

復現

數據表DDL如下,使用 user_id 作為主鍵索引:

 CREATE TABLE `user_message` (
   `user_id` varchar(50) NOT NULL COMMENT '用戶ID',
   `msg_id` int(11) NOT NULL COMMENT '消息ID',
   PRIMARY KEY (`user_id`)
 ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

執行下面的查詢語句,發現雖然 key 顯示使用了主鍵索引,但是 rows顯示掃描了全表,主鍵索引并沒有起作用:

 EXPLAIN SELECT COUNT(*) FROM user_message WHERE user_id = 1;
 ​
 id|select_type|table       |partitions|type |possible_keys|key    |key_len|ref|rows |filtered|Extra                   |
 --+-----------+------------+----------+-----+-------------+-------+-------+---+-----+--------+------------------------+
  1|SIMPLE     |user_message|          |index|PRIMARY      |PRIMARY|206    |   |10000|    10.0|Using where; Using index|

經過排查發現,數據表中 user_id 字段是 VARCHAR 類型,SQL語句中 user_id是INT 類型。MySQL 在執行語句時會對類型做轉換,應該是在類型轉換后導致主鍵索引失效。

隱式轉換

MySQL 的官方文檔:https://dev.mysql.com/doc/refman/8.0/en/type-conversion.html,介紹了 MySQL類型隱式轉換的規則:

當算子兩邊的操作數類型不一致時,MySQL會發生類型轉換以使操作數兼容,這些轉換是隱式發生的。下面描述了比較操作的隱式轉換:

  • 如果一個或兩個參數均為NULL,則比較結果為NULL;但是 => 相等比較運算符除外,對于NULL => NULL,結果為true,無需轉換。
  • 如果比較操作中的兩個參數都是字符串,則將它們作為字符串進行比較。
  • 如果兩個參數都是整數,則將它們作為整數進行比較。
  • 如果不將十六進制值與數字進行比較,則將其視為二進制字符串。
  • 如果參數之一是TIMESTAMP或DATETIME列,而另一個參數是常量,則在執行比較之前,該常量將轉換為時間戳。對于IN() 的參數不執行此操作。為了安全起見,在進行比較時,請始終使用完整的日期時間,日期或時間字符串。例如,要在將BETWEEN與日期或時間值一起使用時獲得最佳結果,請使用CAST()將這些值顯式轉換為所需的數據類型。
  • 一個或多個表中的單行子查詢不視為常量。例如,如果子查詢返回的整數要與DATETIME值進行比較,則比較將作為兩個整數完成,整數不轉換為時間值。參見上一條,這種情況下請使用CAST()將子查詢的結果整數值轉換為DATETIME。
  • 如果參數之一是十進制值,則比較取決于另一個參數。如果另一個參數是十進制或整數值,則將參數作為十進制值進行比較;如果另一個參數是浮點值,則將參數作為浮點值進行比較。
  • 在所有其他情況下,將參數作為浮點數(實數)進行比較。例如,將字符串和數字操作數進行比較,將其作為浮點數的比較。

根據上述規則的最后一條,在前面的SQL語句中,字符串與整數的比較會被轉換成兩個浮點數比較,左邊是字符串類型 "1" 轉換成浮點數為1.0,右邊 INT類型的 1 轉換成浮點數 1.0 。

按理說,兩邊都是浮點數,那么應該能使用索引,為什么執行時沒有使用到?

原因在于,MySQL 中字符串轉浮點型時的轉換規則,規則如下:

1、不以數字開頭的字符串都將轉換為0:

 SELECT CAST('abc' AS UNSIGNED)
 ​
 CAST('abc' AS UNSIGNED)|
 -----------------------+
                       0|

2、以數字開頭的字符串轉換時會進行截取,從第一個字符截取到第一個非數字內容為止:

 SELECT CAST(' 0123abc' AS UNSIGNED)
 ​
 CAST(' 0123abc' AS UNSIGNED)|
 ----------------------------+
                          123|

所以,在 MySQL 里 "1"、 " 1"、"1a" 、"01"這樣的字符串轉成數字后都是 1 。

MySQL在執行上面的SQL語句時,會把每一行主鍵列的值轉換成浮點數(在主鍵上執行了函數CAST),再與條件參數做比較。在索引列上使用函數,會導致索引失效,所以最后導致了全表掃描。

我們只需要把前面SQL中傳入的參數改為字符串,就可以使用到主鍵索引:

 EXPLAIN SELECT COUNT(*) FROM user_message WHERE user_id = '1';
 ​
 id|select_type|table       |partitions|type|possible_keys|key    |key_len|ref  |rows|filtered|Extra      |
 --+-----------+------------+----------+----+-------------+-------+-------+-----+----+--------+-----------+
  1|SIMPLE     |user_message|          |ref |PRIMARY      |PRIMARY|202    |const| 135|   100.0|Using index|

總結

1、條件列是字符串時,如果傳入的條件參數是整數,會先轉換成浮點數,再全表掃描,導致索引失效;
2、條件參數要盡可能與列的類型相同,避免隱式轉換,或者在傳入的參數上執行轉換函數,轉換成與索引列相同的類型。

參考

1、淺析 MySQL 的隱式轉換

到此這篇關于MySQL隱式類型轉換導致索引失效的解決的文章就介紹到這了,更多相關MySQL隱式類型轉換導致索引失效內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • 解決mysql模糊查詢索引失效問題的幾種方法
  • MySQL索引失效的典型案例
  • mysql索引失效的幾種情況分析
  • Mysql 5.6 "隱式轉換"導致的索引失效和數據不準確的問題
  • MySQL索引失效的幾種情況詳析
  • MySQL索引失效的幾種情況匯總
  • 導致MySQL索引失效的一些常見寫法總結
  • mysql回表致索引失效案例講解

標簽:溫州 阿里 三明 揚州 山西 無錫 福州 定西

巨人網絡通訊聲明:本文標題《MySQL隱式類型轉換導致索引失效的解決》,本文關鍵詞  MySQL,隱式,類型,轉換,導致,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《MySQL隱式類型轉換導致索引失效的解決》相關的同類信息!
  • 本頁收集關于MySQL隱式類型轉換導致索引失效的解決的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    亚洲一二三区视频在线观看| 一区二区三区日韩在线观看| 91麻豆国产在线观看| 午夜婷婷国产麻豆精品| 国产日韩欧美高清| 7777女厕盗摄久久久| 91免费版pro下载短视频| 久久不见久久见免费视频1| 亚洲精品国产一区二区精华液 | 亚洲精品成人在线| 精品国产百合女同互慰| 在线精品亚洲一区二区不卡| 成人免费毛片a| 韩国成人精品a∨在线观看| 亚洲线精品一区二区三区| 国产精品素人视频| 精品国产乱码久久久久久浪潮| 欧美亚洲动漫另类| 91在线视频网址| 国产成人在线色| 久久99精品国产| 日韩国产精品久久久久久亚洲| 亚洲美女偷拍久久| 亚洲欧洲一区二区三区| 久久精品在线免费观看| 精品国产乱码久久久久久1区2区| 欧美日韩亚洲丝袜制服| 91成人免费电影| 91在线观看下载| 成人开心网精品视频| 国产69精品一区二区亚洲孕妇| 美女网站色91| 久久国产麻豆精品| 久久电影网电视剧免费观看| 日韩成人免费看| 奇米777欧美一区二区| 亚洲国产成人精品视频| 亚洲综合激情另类小说区| 亚洲欧美日韩国产中文在线| 亚洲一区国产视频| 一二三四社区欧美黄| 亚洲色图在线视频| 亚洲男同1069视频| 夜夜嗨av一区二区三区四季av| 亚洲精品免费电影| 一区二区久久久久| 亚洲狠狠爱一区二区三区| 亚洲一区二区三区四区在线免费观看| 亚洲精品五月天| 亚洲小说春色综合另类电影| 天堂久久久久va久久久久| 五月婷婷久久丁香| 男男视频亚洲欧美| 国产一区二区三区高清播放| 国产精品1024| av电影天堂一区二区在线观看| www.色综合.com| 91久久一区二区| 欧美日本国产一区| 精品少妇一区二区三区日产乱码 | 中文字幕制服丝袜一区二区三区| 综合精品久久久| 亚洲福利视频导航| 日韩成人免费在线| 国产精品一区二区在线观看网站| 成人免费视频caoporn| 日本电影亚洲天堂一区| 777精品伊人久久久久大香线蕉| 日韩欧美高清一区| 国产欧美一区二区精品性色| 国产精品福利一区| 午夜av电影一区| 国内久久精品视频| 一本在线高清不卡dvd| 欧美久久久久中文字幕| 亚洲精品一区二区精华| 中文字幕中文字幕在线一区 | 天堂在线一区二区| 国产精品一级在线| 日本高清不卡视频| 精品国产精品网麻豆系列 | 另类小说视频一区二区| 成人丝袜高跟foot| 欧美日韩国产高清一区二区| 久久精品一二三| 一区二区三区av电影| 九一久久久久久| 97精品久久久午夜一区二区三区| 欧美伊人久久久久久久久影院| 精品成人在线观看| 亚洲自拍偷拍图区| 国产激情91久久精品导航| 在线亚洲免费视频| 国产日韩一级二级三级| 五月天久久比比资源色| 成人精品在线视频观看| 777久久久精品| 亚洲色图欧洲色图| 国产美女娇喘av呻吟久久| 欧美亚男人的天堂| 欧美国产精品劲爆| 国产精品一区二区三区网站| 欧美亚州韩日在线看免费版国语版| 久久免费精品国产久精品久久久久| 亚洲精品水蜜桃| 风流少妇一区二区| 精品精品欲导航| 亚洲成a人片在线不卡一二三区| 国产jizzjizz一区二区| 4438x成人网最大色成网站| 中文字幕欧美一| 国产乱码精品一区二区三区忘忧草| 欧美日韩成人高清| 亚洲免费在线看| 成人福利视频在线看| 精品国产乱码久久久久久蜜臀| 亚洲bt欧美bt精品777| 日本道在线观看一区二区| 国产日韩精品一区二区三区 | 一区二区三区欧美在线观看| 波多野结衣中文一区| 国产亚洲一区二区三区四区| 美女在线视频一区| 91精品国产综合久久福利 | 亚洲欧美成aⅴ人在线观看| 国产成人一级电影| 久久久久88色偷偷免费| 国产在线精品一区二区夜色| 日韩免费视频线观看| 免费在线观看视频一区| 欧美日本一区二区三区四区| 亚洲自拍偷拍麻豆| 在线精品亚洲一区二区不卡| 一区二区三区欧美视频| 日本黄色一区二区| 亚洲日本青草视频在线怡红院| kk眼镜猥琐国模调教系列一区二区 | 欧美男人的天堂一二区| 亚洲一区二三区| 欧美日韩免费观看一区二区三区| 亚洲日本va午夜在线电影| 91猫先生在线| 亚洲欧美aⅴ...| 日本韩国精品在线| 亚洲制服丝袜在线| 在线综合亚洲欧美在线视频| 婷婷丁香激情综合| 91精品国产全国免费观看| 日本v片在线高清不卡在线观看| 欧美日韩mp4| 美国av一区二区| 日韩欧美亚洲国产精品字幕久久久| 全国精品久久少妇| 久久青草欧美一区二区三区| 国产精品亚洲成人| 中文字幕一区二区在线观看| 北岛玲一区二区三区四区| 亚洲人成在线播放网站岛国| 在线一区二区三区| 日韩激情视频网站| 欧美不卡一区二区三区四区| 国产v日产∨综合v精品视频| 亚洲免费观看高清| 欧美一区二区三区四区在线观看| 国内精品久久久久影院薰衣草| 国产欧美精品国产国产专区| www..com久久爱| 三级影片在线观看欧美日韩一区二区| 在线不卡的av| 成人综合日日夜夜| 亚洲午夜羞羞片| 久久久久国产精品人| 日韩欧美一级在线播放| 国产精品综合在线视频| 亚洲乱码国产乱码精品精可以看| 欧美猛男gaygay网站| 国产麻豆91精品| 亚洲综合激情网| 久久久久久电影| 欧美亚洲动漫另类| 国产精品18久久久久久久久| 亚洲免费观看高清| 精品盗摄一区二区三区| 一本色道久久综合狠狠躁的推荐 | 日韩女优av电影| 波多野结衣视频一区| 日韩二区三区在线观看| 国产精品色一区二区三区| 91精品国模一区二区三区| 国产精品亚洲专一区二区三区 | 国产一级精品在线| 一区二区三区免费网站| 26uuu精品一区二区在线观看| 91在线观看美女| 久久不见久久见免费视频7| 亚洲激情欧美激情| 久久这里只有精品首页| 欧美日韩精品三区| 91色综合久久久久婷婷| 国产裸体歌舞团一区二区|