亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么使用MySQL的覆蓋索引

發布時間:2021-02-01 09:33:41 來源:億速云 閱讀:479 作者:小新 欄目:開發技術

這篇文章給大家分享的是有關怎么使用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的覆蓋索引”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

瑞安市| 沂南县| 贵州省| 桃源县| 务川| 两当县| 开封县| 常山县| 阳江市| 成武县| 彰武县| 浦北县| 磐石市| 开封县| 加查县| 阜阳市| 富平县| 阜城县| 商丘市| 阿合奇县| 渭源县| 奈曼旗| 聊城市| 江西省| 沁水县| 朝阳县| 和林格尔县| 沂水县| 阿尔山市| 翼城县| 波密县| 新化县| 含山县| 黎城县| 张家川| 厦门市| 乌兰浩特市| 巨鹿县| 望谟县| 杨浦区| 民乐县|