聯合索引應用細節

2021-10-08 07:29:09 字數 2174 閱讀 8553

只要我們將來的查詢,所有索引列都是《等值》查詢條件下,無關排列順序 

唯一值多的列放在最左側

abcd 

acbd

adbc

acbd

等等mysql> desc  select * from test where k1='aa' and k2='中國' and k3='aaaa' and k4='中國你好';

mysql> desc  select * from test where  k2='中國' and k3='aaaa' and k4='中國你好' and k1='aa';

原因: 優化器,自動做查詢條件的排列

不連續部分條件 

cda   ----> acd   ---> a  -----> idx(c,d,a)

dba   ----> abd   ---> ab ---->  idx(d,b,a)

在where查詢中如果出現》 < >= <= like 

(1)mysql> desc  select * from test where k1='aa'  and k3='aaaa' and k4='中國你好' and  k2>'中國';

(2) 

mysql> alter table test add index idx1(k1,k3,k4,k2);

多子句     查詢,應用聯合索引

mysql> desc select * from test where k1='aa' order by k2;

mysql> alter table test add index idx3(k1,k2);

explain(desc)使用場景(面試題)

你做過哪些優化?

你用過什麼優化工具?

你對索引這塊怎麼優化的?

題目意思:  我們公司業務慢,請你從資料庫的角度分析原因

1.mysql出現效能問題,我總結有兩種情況:

(1)應急性的慢:突然夯住

應急情況:資料庫夯(卡了,資源耗盡)

處理過程:

1.show processlist;  獲取到導致資料庫hang的語句

2. explain 分析sql的執行計畫,有沒有走索引,索引的型別情況

3. 建索引,改語句

(2)一段時間慢(持續性的):

(1)記錄慢日誌slowlog,分析slowlog

(2)explain 分析sql的執行計畫,有沒有走索引,索引的型別情況

(3)建索引,改語句

索引應用規範

建立索引的原則(dba運維規範)

(1) 建表必須要有主鍵,一般是無關列,自增長

(2) 經常做為where條件列  order by  group by  join on, distinct 的條件

(3) 最好使用唯一值多的列作為聯合索引前導列,其他的按照聯合索引優化細節來做

(4) 列值長度較長的索引列,我們建議使用字首索引.

(5) 降低索引條目,一方面不要建立沒用索引,不常使用的索引清理,percona toolkit(***xx)

(6) 索引維護要避開業務繁忙期

(7) 小表不建索引

不走索引的情況(開發規範)

(1) 沒有查詢條件,或者查詢條件沒有建立索引

select * from city;

select * from city where 1=1;

(2) 查詢結果集是原表中的大部分資料,應該是25%以上。

(3) 索引本身失效,統計資料不真實

面試題:同乙個語句突然變慢?

統計資訊過舊,導致的索引失效

(4) 查詢條件使用函式在索引列上,或者對索引列進行運算,運算包括(+,-,*,/,! 等)

mysql> desc select * from city where id-99=1;

(5) 隱式轉換導致索引失效.

注:在建表的時候ident列使用的是varchar型別(因為身份證中有可能會保險x字元,所以),我們在ident(身份證)這列建立了索引,在查詢的時候 select * from student where ident=1234567; 這樣查詢是不會走索引的 ,因為ident列的型別是字元型別,所以在查詢的時候需要  '1234567'

(6) <> ,not in 不走索引(輔助索引)

(7) like "%aa" 百分號在最前面不走

(8) 聯合索引裡非第一位置的索引列

MySQL聯合索引or 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進行查詢 當最左側欄位是常量引用時,索引就十分有效。兩個或更多個...