MySQL覆蓋索引的使用示例

2021-10-18 11:50:40 字數 1228 閱讀 4851

什麼是覆蓋索引

建立乙個索引,該索引包含查詢中用到的所有字段,稱為「覆蓋索引」。

使用覆蓋索引,mysql 只需要通過索引就可以查詢和返回查詢所需要的資料,而不必在使用索引處理資料之後再進行回表操作。

覆蓋索引可以一次性完成查詢工作,有效減少io,提高查詢效率。

使用示例

查詢語句:

1select col2, col3 from test_table where col1 = *** order by col2;

建立乙個單列索引:

1alter table `test_table` add index `idx_col1`(`col1`) using btree;

分析查詢:

1explain select sql_no_cache col2, col3 from test_table where col1 = *** order by col2;

結果:對 col1 建立索引後,type 為 ref,使用到了 idx_col1 索引。

修改索引,根據查詢語句,建立乙個聯合索引:12

alter table `test_table` drop index `idx_col1`;

alter table `test_table` add index `idx_col1_col2_col3`(`col1`,`col2`,`col3`) using btree;

分析查詢:

1explain select sql_no_cache col2, col3 from test_table where col1 = *** order by col2;

結果:建立聯合索引後,type 為 ref,使用了 idx_col1_col2_col3 索引,extra 為 using index,說明使用了覆蓋索引。

mysql覆蓋索引和聯合索引的區別

覆蓋索引zhi是查詢的列可dao以直接通過索引zhuan提取,比如只查詢主鍵shu的列!或者查詢聯合索引的所有列或者左邊開始的部分列(注意有順序的)!

而聯合索引並不一定只從索引中能獲取到所有的資料,這個取決於你所查詢的列。比如select * from table where ××××××;的方式就不太可能是覆蓋索引。因此如果你查詢的列能用到聯合索引,且你查詢的列都能通過聯合索引獲取,比如你只查詢聯合索引所在的列或者左邊開始的部分列,這就相當於覆蓋索引了。通常為了讓查詢能用到覆蓋索引,就將要查詢的多列資料設定成聯合索引。

總結到此這篇關於mysql覆蓋索引使用的文章就介紹到這了

MySQL覆蓋索引的使用示例

建立乙個索引,該索引包含查詢中用到的所有字段,稱為 覆蓋索引 使用覆蓋索引,mysql 只需要通過索引就可以查詢和返程式設計客棧回查詢所需要的資料,而不必在使用索引處理資料之後再進行回表操作。程式設計客棧覆蓋索引可以一次性完成查詢工作,有效減少io,提高查詢效率。查詢語句 select col2,c...

mysql覆蓋索引 MySQL 的覆蓋索引與回表

兩大類索引 使用的儲存引擎 mysql5.7 innodb 聚簇索引 如果表設定了主鍵,則主鍵就是聚簇索引 如果表沒有主鍵,則會預設第乙個not null,且唯一 unique 的列作為聚簇索引 以上都沒有,則會預設建立乙個隱藏的row id作為聚簇索引 innodb的聚簇索引的葉子節點儲存的是行記...

MySQL覆蓋索引呼叫 MySQL 覆蓋索引

什麼是覆蓋索引 建立乙個索引,該索引包含查詢中用到的所有字段,稱為 覆蓋索引 使用覆蓋索引,mysql 只需要通過索引就可以查詢和返回查詢所需要的資料,而不必在使用索引處理資料之後再進行回表操作。覆蓋索引可以一次性完成查詢工作,有效減少io,提高查詢效率。使用示例 查詢語句 select col2,...