如果一個(gè)索引包含(或覆蓋)所有需要查詢的字段的值,稱為‘覆蓋索引’。這篇文章主要給大家介紹了關(guān)于MySQL覆蓋索引的相關(guān)資料,需要的朋友可以參考下
什么是覆蓋索引
創(chuàng)建一個(gè)索引,該索引包含查詢中用到的所有字段,稱為“覆蓋索引”。
使用覆蓋索引,MySQL 只需要通過索引就可以查找和返回查詢所需要的數(shù)據(jù),而不必在使用索引處理數(shù)據(jù)之后再進(jìn)行回表操作。
覆蓋索引可以一次性完成查詢工作,有效減少IO,提高查詢效率。
使用示例
查詢語句:
SELECT col2, col3 FROM test_table WHERE col1 = xxx ORDER BY col2;
創(chuàng)建一個(gè)單列索引:
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;
結(jié)果:對(duì) col1 建立索引后,type 為 ref,使用到了 idx_col1 索引。
修改索引,根據(jù)查詢語句,建立一個(gè)聯(lián)合索引:
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;
結(jié)果:建立聯(lián)合索引后,type 為 ref,使用了 idx_col1_col2_col3 索引,Extra 為 Using index,說明使用了覆蓋索引。
mysql覆蓋索引和聯(lián)合索引的區(qū)別
覆蓋索引zhi是查詢的列可dao以直接通過索引zhuan提取,比如只查詢主鍵shu的列!或者查詢聯(lián)合索引的所有列或者左邊開始的部分列(注意有順序的)!
而聯(lián)合索引并不一定只從索引中能獲取到所有的數(shù)據(jù),這個(gè)取決于你所查詢的列。比如select * from table where ××××××;的方式就不太可能是覆蓋索引。因此如果你查詢的列能用到聯(lián)合索引,且你查詢的列都能通過聯(lián)合索引獲取,比如你只查詢聯(lián)合索引所在的列或者左邊開始的部分列,這就相當(dāng)于覆蓋索引了。通常為了讓查詢能用到覆蓋索引,就將要查詢的多列數(shù)據(jù)設(shè)置成聯(lián)合索引。
總結(jié)
到此這篇關(guān)于MySQL覆蓋索引使用的文章就介紹到這了,更多相關(guān)MySQL覆蓋索引內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
來源:腳本之家
鏈接:https://www.jb51.net/article/205112.htm
申請(qǐng)創(chuàng)業(yè)報(bào)道,分享創(chuàng)業(yè)好點(diǎn)子。點(diǎn)擊此處,共同探討創(chuàng)業(yè)新機(jī)遇!