程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> MySQL查詢不使用索引匯總

MySQL查詢不使用索引匯總

編輯:MySQL綜合教程

MySQL查詢不使用索引匯總   眾所周知,增加索引是提高查詢速度的有效途徑,但是很多時候,即使增加了索引,查詢仍然不使用索引,這種情況嚴重影響性能,這裡就簡單總結幾條MySQL不使用索引的情況 如果MySQL估計使用索引比全表掃描更慢,則不使用索引。例如,如果列key均勻分布在1和100之間,下面的查詢使用索引就不是很好:select * from table_name where key>1 and key<90;   www.2cto.com   如果使用MEMORY/HEAP表,並且where條件中不使用“=”進行索引列,那麼不會用到索引,head表只有在“=”的條件下才會使用索引 用or分隔開的條件,如果or前的條件中的列有索引,而後面的列沒有索引,那麼涉及到的索引都不會被用到,例如:select * from table_name where key1='a' or key2='b';如果在key1上有索引而在key2上沒有索引,則該查詢也不會走索引 復合索引,如果索引列不是復合索引的第一部分,則不使用索引(即不符合最左前綴),例如,復合索引為(key1,key2),則查詢select * from table_name where key2='b';將不會使用索引   如果like是以‘%’開始的,則該列上的索引不會被使用。例如select * from table_name where key1 like '%a';該查詢即使key1上存在索引,也不會被使用 如果列為字符串,則where條件中必須將字符常量值加引號,否則即使該列上存在索引,也不會被使用。例如,select * from table_name where key1=1;如果key1列保存的是字符串,即使key1上有索引,也不會被使用。   www.2cto.com   從上面可以看出,即使我們建立了索引,也不一定會被使用,那麼我們如何知道我們索引的使用情況呢??在MySQL中,有Handler_read_key和Handler_read_rnd_key兩個變量,如果Handler_read_key值很高而Handler_read_rnd_key的值很低,則表明索引經常不被使用,應該重新考慮建立索引。可以通過:show status like 'Handler_read%'來查看著連個參數的值。  

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved