您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關(guān)怎么使用MySQL的覆蓋索引的內(nèi)容。小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過(guò)來(lái)看看吧。
創(chuàng)建一個(gè)索引,該索引包含查詢中用到的所有字段,稱為“覆蓋索引”。
使用覆蓋索引,MySQL 只需要通過(guò)索引就可以查找和返回查詢所需要的數(shù)據(jù),而不必在使用索引處理數(shù)據(jù)之后再進(jìn)行回表操作。
覆蓋索引可以一次性完成查詢工作,有效減少I(mǎi)O,提高查詢效率。
查詢語(yǔ)句:
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ù)查詢語(yǔ)句,建立一個(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,說(shuō)明使用了覆蓋索引。
覆蓋索引zhi是查詢的列可dao以直接通過(guò)索引zhuan提取,比如只查詢主鍵shu的列!或者查詢聯(lián)合索引的所有列或者左邊開(kāi)始的部分列(注意有順序的)!
而聯(lián)合索引并不一定只從索引中能獲取到所有的數(shù)據(jù),這個(gè)取決于你所查詢的列。比如select * from table where ××××××;的方式就不太可能是覆蓋索引。因此如果你查詢的列能用到聯(lián)合索引,且你查詢的列都能通過(guò)聯(lián)合索引獲取,比如你只查詢聯(lián)合索引所在的列或者左邊開(kāi)始的部分列,這就相當(dāng)于覆蓋索引了。通常為了讓查詢能用到覆蓋索引,就將要查詢的多列數(shù)據(jù)設(shè)置成聯(lián)合索引。
感謝各位的閱讀!關(guān)于“怎么使用MySQL的覆蓋索引”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。