<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
日常工作中索引失效原因很多,這個需要平時的日積月累,不斷學習,才能更正確的發揮索引的作用,下面簡單總結一些索引失效原因。
select * from test where num=13911111111; # 失效,num欄位是varchar型別,沒有加引號
假設某手機號列建立時是num varchar(15)
如果上面的手機號沒有加引號,查詢的時候是字串跟數位的比較,它們型別不匹配,MySQL 會做隱式的型別轉換,把它們轉換為浮點數再做比較。隱式的型別轉換,索引會失效。
select * from test where mul=1 or noidx=2; # 可能失效,當mul設為索引列而noidx不是索引列時
索引+or+無索引的列:會先走索引列,但無索引的列會進行全表掃描,所以還不如不走索引,直接都全表掃描完事。如果or前後都有索引,那麼可能走索引,也可能不走索引。
如果它一開始就走全表掃描,直接一遍掃描就完事。Mysql 優化器出於效率與成本考慮,遇到 or 條件,讓索引失效,看起來也合情合理。
用or連線的兩個含null索引欄位,不走索引。但是,單個索引含null欄位,是走索引的。
注意:如果 or 條件的列都加了索引,索引可能會走也可能不走,平時大家使用的時候,還是要注意一下這個 or,學會用 explain 分析。遇到不走索引的時候,考慮拆開兩條 SQL。
並不是用了 like 萬用字元,索引一定會失效,而是 like 查詢是以 % 開頭,才會導致索引失效。
MySQl 建立聯合索引時,會遵循最左字首匹配的原則,即最左優先。如果你建立一個(a,b,c)的聯合索引,相當於建立了 (a)、(a,b)、(a,b,c) 三個索引。
select * from user where DATE_ADD(login_time,INTERVAL 1 DAY) = '2022-11-08 00:00:00'; # 失效 select * from user where login_time = DATE_ADD('2022-11-08 00:00:00',INTERVAL 1 DAY); # 有效
select * from user where age-1 = 39; # 失效
select * from user where age != 18; # 有可能失效
其實這個也是跟 mySQL優化器有關,如果優化器覺得即使走了索引,還是需要掃描很多很多行的哈,它覺得不划算,不如直接不走索引。平時我們用!= 或者 < >,not in 的時候,要留點心眼。
很多時候,是因為資料量問題,導致了 MySQL 優化器放棄走索引。同時,平時我們用 explain 分析 SQL 的時候,如果 type=range, 要注意一下哈,因為這個可能因為資料量問題,導致索引無效。
如user 表的 name 欄位編碼是 utf8mb4,而 user_job 表的 name 欄位編碼為 utf8。
雖然索引有自我維護的能力,但資料表內容修改和更新頻繁的情況下,也有可能索引失效,此時需要刪除索引,重新建立索引。
關於索引失效原因有很多,以上也只是簡單介紹了一下,具體失效原因,還得去自己分析,具體方法就是SQL的執行計劃 EXPLAIN 關鍵字了。
Mysql提供了這個關鍵字讓我們優化索引,使查詢更快,分析優化器的表連線,使它採用最優的順序。使用這個 explain 關鍵字可以檢視查詢語句是否走索引了以及走了哪個索引。
# 命令列執行以下語句即可檢視查詢語句是否走了索引,在查詢語句最前面加上 explain 即可 mysql> explain select * from sampleInfo where agents = "XXX中心有限公司";
如下圖的 key 即表示該語句使用了索引 agents 。如果下圖 key 那裡的為NULL或者 type 那裡為ALL,則表示該語句沒有走索引,需要進行優化了。
到此這篇關於MySQL索引失效原因以及SQL查詢語句不走索引原因的文章就介紹到這了,更多相關MySQL索引失效原因內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45