只要我們將來的查詢,所有索引列都是《等值》查詢條件下,無關排列順序
唯一值多的列放在最左側
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進行查詢 當最左側欄位是常量引用時,索引就十分有效。兩個或更多個...