MySQL覆蓋索引的使用示例
什麼是覆蓋索引
創建一個索引,該索引包含查詢中用到的所有字段,稱為“覆蓋索引”。
使用覆蓋索引,MySQL 隻需要通過索引就可以查找和返回查詢所需要的數據,而不必在使用索引處理數據之後再進行回表操作。
覆蓋索引可以一次性完成查詢工作,有效減少IO,提高查詢效率。
使用示例
查詢語句:
SELECT col2, col3 FROM test_table WHERE col1 = xxx ORDER BY col2;
創建一個單列索引:
ALTER TABLE `test_table` ADD INDEX `idx_col1`(`col1`) USING BTREE;
分析查詢:
EXPLAIN SELECT SQL_NO_CACHE col2, col3 FROM test_table WHERE col1 = xxx ORDER BY col2;
結果:對 col1 建立索引後,type 為 ref,使用到瞭 idx_col1 索引。
修改索引,根據查詢語句,建立一個聯合索引:
ALTER TABLE `test_table` DROP INDEX `idx_col1`; ALTER TABLE `test_table` ADD INDEX `idx_col1_col2_col3`(`col1`,`col2`,`col3`) USING BTREE;
分析查詢:
EXPLAIN SELECT SQL_NO_CACHE col2, col3 FROM test_table WHERE col1 = xxx ORDER BY col2;
結果:建立聯合索引後,type 為 ref,使用瞭 idx_col1_col2_col3 索引,Extra 為 Using index,說明使用瞭覆蓋索引。
mysql覆蓋索引和聯合索引的區別
覆蓋索引zhi是查詢的列可dao以直接通過索引zhuan提取,比如隻查詢主鍵shu的列!或者查詢聯合索引的所有列或者左邊開始的部分列(註意有順序的)!
而聯合索引並不一定隻從索引中能獲取到所有的數據,這個取決於你所查詢的列。比如select * from table where ××××××;的方式就不太可能是覆蓋索引。因此如果你查詢的列能用到聯合索引,且你查詢的列都能通過聯合索引獲取,比如你隻查詢聯合索引所在的列或者左邊開始的部分列,這就相當於覆蓋索引瞭。通常為瞭讓查詢能用到覆蓋索引,就將要查詢的多列數據設置成聯合索引。
總結
到此這篇關於MySQL覆蓋索引使用的文章就介紹到這瞭,更多相關MySQL覆蓋索引內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!