上篇介紹了MySql什麼時候會嘗試使用索引,本文介紹一下我瞭解的不會使用索引的情況, 仍然使用上次建立好的表
1. where 子句中like 使用了字首萬用字元 %keyword
select * from test_user where name like "%Kiven%";
複製程式碼
data:image/s3,"s3://crabby-images/e4498/e4498a32bca63307072925af0163d044df5468f1" alt="MySql如何使用索引(二)"
2. 使用>, >=, <,<=, !=,NOT IN 範圍查詢或否定查詢,且範圍查詢時選擇的邊界查詢條件範圍過大
select * from test_user where height>=180
# 不會使用索引
複製程式碼
data:image/s3,"s3://crabby-images/56da9/56da9f94c79769791cc9a87abf599d5c9b7732c1" alt="MySql如何使用索引(二)"
select * from test_user where height>=190
# 會使用索引
複製程式碼
data:image/s3,"s3://crabby-images/00810/00810a39339f02889a549d0987157068846f7bdd" alt="MySql如何使用索引(二)"
3. 資料型別隱式轉換
例如:name欄位為varchar型別的
select * from test_user where name=1
複製程式碼
將不能使用索引,而
select * from test_user where name='1'
複製程式碼
可以使用索引
data:image/s3,"s3://crabby-images/f586f/f586f6d9948606c9b50bb34bb291e64c56ec6e5e" alt="MySql如何使用索引(二)"
data:image/s3,"s3://crabby-images/911c6/911c6a1cb1690751d5d322f8b2293729c0d4e16d" alt="MySql如何使用索引(二)"
原因是當不同的欄位型別比較時,MySql會做引式型別轉換,而 int型別的1可能等於 '01', '0001'或者 '01.e1'
4. 不符合最左匹配原則(聯合索引)
我們建立的索引順序是
KEY `idx_name_height_weight` (`name`,`height`,`weight`)
複製程式碼
所以使用的時候where子句也不能跳過前一個聯合索引列
# 比如直接聯合索引的最後一列是不支援的
select * from test_user where weight=65
複製程式碼
data:image/s3,"s3://crabby-images/84c92/84c92e956d8e805a269643b9d566eb9f7436bb19" alt="MySql如何使用索引(二)"
# 而使用全部索引列做查詢條件是可以的
select * from test_user where weight=65 AND name='Tom' AND `height`=160
複製程式碼
data:image/s3,"s3://crabby-images/995a0/995a0d39786b3942a394e11b02c652dd350befc5" alt="MySql如何使用索引(二)"
6. 在索引列上進行運算
select * from test_user where `height`+10=160
#是不會使用索引的,可以寫成
select * from test_user where `height`=160-10
# 就能夠使用索引了
複製程式碼
在索引使用方面MySql本身幫我們做了很多優化,有時候不一定會按照我們的想法去使用索引,接下來還需要探索