主頁 > 知識庫 > MySQL覆蓋索引的使用示例

MySQL覆蓋索引的使用示例

熱門標簽:武漢網絡外呼系統服務商 啥是企業400電話辦理 百應電話機器人優勢 電話外呼系統改號 地圖標注費用是多少 怎樣在地圖標注銷售區域 南昌三維地圖標注 外呼系統打電話上限是多少 曲靖移動外呼系統公司

什么是覆蓋索引

創建一個索引,該索引包含查詢中用到的所有字段,稱為“覆蓋索引”。

使用覆蓋索引,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覆蓋索引內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • mysql利用覆蓋索引避免回表優化查詢
  • mysql中關于覆蓋索引的知識點總結
  • MySQL 的覆蓋索引與回表的使用方法
  • Mysql覆蓋索引詳解
  • Mysql性能優化案例 - 覆蓋索引分享
  • Mysql性能優化案例研究-覆蓋索引和SQL_NO_CACHE
  • MySQL 覆蓋索引的優點

標簽:黑河 滄州 隨州 資陽 甘南 吉林 錦州 荊州

巨人網絡通訊聲明:本文標題《MySQL覆蓋索引的使用示例》,本文關鍵詞  MySQL,覆蓋,索引,的,使用,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《MySQL覆蓋索引的使用示例》相關的同類信息!
  • 本頁收集關于MySQL覆蓋索引的使用示例的相關信息資訊供網民參考!
  • 推薦文章
    2020久久精品亚洲|久久窝窝国产精品午夜看片|亚洲 日韩 激情 无码 中出|国产精品乱码高清在线