什麼是覆蓋索引
建立乙個索引,該索引包含查詢中用到的所有字段,稱為「覆蓋索引」。
使用覆蓋索引,mysql 只需要通過索引就可以查詢和返回查詢所需要的資料,而不必在使用索引處理資料之後再進行回表操作。
覆蓋索引可以一次性完成查詢工作,有效減少io,提高查詢效率。
使用示例
查詢語句:
select col2, col3 from test_table where col1 = *** 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 = *** 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 = *** order by col2;
結果:建立聯合索引後,type 為 ref,使用了 idx_col1_col2_col3 索引,extra 為 using index,說明使用了覆蓋索引。
MySQL 索引 覆蓋索引
1.什麼是覆蓋索引?概念 查詢語句中所需要的列在索引中,這樣查詢結果在索引的資料結構中查詢即可拿到結果。附加解釋 2.形成覆蓋索引的條件索引分為多種型別,從資料結構上分為 二叉樹 紅黑樹 hash索引 b tree索引,b tree mysql使用的儲存結構 索引的實現可以使用多種資料結構,這裡使用...
mysql覆蓋索引 MySQL 的覆蓋索引與回表
兩大類索引 使用的儲存引擎 mysql5.7 innodb 聚簇索引 如果表設定了主鍵,則主鍵就是聚簇索引 如果表沒有主鍵,則會預設第乙個not null,且唯一 unique 的列作為聚簇索引 以上都沒有,則會預設建立乙個隱藏的row id作為聚簇索引 innodb的聚簇索引的葉子節點儲存的是行記...
mysql覆蓋索引
覆蓋索引又可以稱為索引覆蓋。解釋一 就是select的資料列只用從索引中就能夠取得,不必從資料表中讀取,換句話說查詢列要被所使用的索引覆蓋。解釋二 索引是高效找到行的乙個方法,當能通過檢索索引就可以讀取想要的資料,那就不需要再到資料表中讀取行了。如果乙個索引包含了 或覆蓋了 滿足查詢語句中字段與條件...