溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

怎么使用MySQL的覆蓋索引

發(fā)布時(shí)間:2021-02-01 09:33:41 來(lái)源:億速云 閱讀:483 作者:小新 欄目:開(kāi)發(fā)技術(shù)

這篇文章給大家分享的是有關(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ō)明使用了覆蓋索引。

mysql覆蓋索引和聯(lián)合索引的區(qū)別

覆蓋索引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ò),可以把它分享出去讓更多的人看到吧!

向AI問(wèn)一下細(xì)節(jié)

免責(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)容。

AI