mysql聯合索引命中條件

2022-06-28 07:15:08 字數 859 閱讀 5381

轉於:

首先明確:為什麼要用聯合索引?

對於查詢語句「select e.* from e where e.e1=1 and e.e3=2」涉及到兩列,這個時候我們一般採用乙個聯合索引(e1, e3);而不用兩個單列索引,這是因為一條查詢語句往往應為mysql優化器的關係只用乙個索引,就算你有兩個索引,他也只用乙個;在只用乙個的基礎之上,聯合索引是會比單列索引要快的;

下面講講聯合索引的使用規則和哪些情況會命中不了聯合索引

示例如下。首先建立表:

create table e (e1 int, e2 varchar(9), e3 int, primary key(e1, e3));

這樣就建立了乙個聯合索引:e1,e3

測試資料

insert into e

(e1, e2, e3)

values(1, 'aa', 2);

觸發聯合索引是有條件的:

1、使用聯合索引的全部索引鍵,可觸發索引的使用。

例如:select e.* from e where e.e1=1 and e.e3=2

2、使用聯合索引的字首部分索引鍵,如「key_part_1 常量」,可觸發索引的使用。

例如:select e.* from e where e.e1=1

3、使用部分索引鍵,但不是聯合索引的字首部分,如「key_part_2 常量」,不可觸發索引的使用。

例如:select e.* from e where e.e3=1

4、使用聯合索引的全部索引鍵,但索引鍵不是and操作,不可觸發索引的使用。

例如:select e.* from e where e.e3=2 or e.e1=1

以上通過explain測試即可看出效果

mysql普通索引命中 mysql索引命中規則

轉於 首先明確 為什麼要用聯合索引?對於查詢語句 select e.from e where e.e1 1 and e.e3 2 涉及到兩列,這個時候我們一般採用乙個聯合索引 e1,e3 而不用兩個單列索引,這是因為一條查詢語句往往應為mysql優化器的關係只用乙個索引,就算你有兩個索引,他也只用乙...

mysql聯合索引詳解 mysql 聯合索引詳解

聯合索引又叫復合索引。對於復合索引 mysql從左到右的使用索引中的字段,乙個查詢可以只使用索引中的一部份,但只能是最左側部分。例如索引是key index a,b,c 可以支援a a,b a,b,c 3種組合進行查詢,但不支援 b,c進行查詢 當最左側欄位是常量引用時,索引就十分有效。兩個或更多個...

mysql聯合索引技術 mysql 聯合索引詳解

聯合索引又叫復合索引。對於復合索引 mysql從左到右的使用索引中的字段,乙個查詢可以只使用索引中的一部份,但只能是最左側部分。例如索引是key index a,b,c 可以支援a a,b a,b,c 3種組合進行查詢,但不支援 b,c進行查詢 當最左側欄位是常量引用時,索引就十分有效。兩個或更多個...