天天做天天爱天天综合网-天天做天天爱天天影视综合-天天做天天爱天天爽综合区-天天做天天爱天天爽天天综合-福利一区二区在线观看-福利一区二区视频

互聯網+內容
134-1887-2552

MySQL覆蓋索引的使用示例

標簽:深圳網站建設公司2021-02-05 805

如果一個索引包含(或覆蓋)所有需要查詢的字段的值,稱為‘覆蓋索引’。這篇文章主要給大家介紹了關于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覆蓋索引內容請搜索深圳網站建設公司自由創想以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持深圳網站建設公司自由創想!

微信分享領紅包!
相關閱讀 / 返回上一頁
主站蜘蛛池模板: 亚欧洲精品在线视频免费观看| 91精品久久久久| 欧美成人精品在线| 唯美清纯另类亚洲| 大黄毛片| 国产三级一区二区| 精品一区二区三区四区| 91精品国产9l久久久久| 一区欧美| 国产伊人久久| 国产一区二区高清视频| 国产美女视频黄a视频全免费网站| 久久一次| 97一区二区三区四区久久| a集毛片| 久久婷婷久久一区二区三区| 国产伊人久久| 国产日韩欧美中文字幕| 日韩在线欧美在线| 亚洲 国产 日韩 欧美| 欧美国产综合在线| 国产黄色片在线观看| 欧美第一精品| 亚洲精品视频免费观看| 欧美一区二区精品| 国产正在播放| 日韩在线一区二区三区免费视频| a级网站| 精品免费久久久久国产一区 | 国内精品久久久久久久aa护士| 国产精选一区二区| 亚洲欧美天堂网| 欧美精品三区| 手机国产精品一区二区| 在线观看亚洲一区二区| 黄毛片| 自拍偷拍欧美亚洲| 国产精品视频3p| 特一级大黄在线观看| 久久er99| 亚洲精品国产精品国自产观看|