日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

mysql 字符串索引 优化_MySQL性能优化之索引调优实战

發布時間:2024/4/14 数据库 42 豆豆
生活随笔 收集整理的這篇文章主要介紹了 mysql 字符串索引 优化_MySQL性能优化之索引调优实战 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

索引失效場景或使用注意事項

a、索引無法存儲null值,所以建議都給默認值

b、如果條件中有or,即使使用了索引條件也不起作用,所以盡量少用or

如果想使用or,又讓索引生效,只能將or的每個列上加上索引

c、對于多列索引,不是使用其中的第一部分,則不會使用索引。

d、like查詢以%開頭(like '%XX'或者like '%XX%')

e、如果列類型是字符串,那一定要在條件中將數據使用引號引用起來,否則不使用索引

f、如果mysql估計使用全表掃描要比使用索引快,則不使用索引

g、索引的字段類型與傳入參數不匹配,則索引失效

索引優化樣例

1.使用索引時,關聯表的條件字段中,字段長度和編碼必須一致

a.fk_user_id = b.user_id ,fk_user_id 的編碼是utf8 而 user_id 的編碼方式是utf8mb4的,所以導致索引失效

2.盡量使用覆蓋索引(只訪問索引的查詢(索引列包含查詢列)),減少select *語句

SELECT name,age FROM employees WHERE name= 'jarye' AND age = 23 AND position ='ceo';----直接走索引

SELECT * FROM employees WHERE name= 'jarye' AND age = 23 AND position ='ceo';-----索引走了還會走二次查詢

3.列類型是字符串,則必須使用''引號,否則不使用索引

SELECT * FROM employees WHERE name = 123;--索引會失效

SELECT * FROM employees WHERE name = '123';--索引生效

4.判斷是否為空用is null,使用=null則不啟用索引

select id from t where num is null;

注意: NULL 與任何值的直接比較都為 NULL。

1 ) NULL<>NULL 的返回結果是 NULL ,而不是 false 。

2 ) NULL=NULL 的返回結果是 NULL ,而不是 true 。

3 ) NULL<>1 的返回結果是 NULL ,而不是 true 。

5.應盡量避免在 where 子句中對”="左邊進行函數、算數運算或表達式運算,這將導致引擎放棄使用索引而進行全表掃描。

select id from t where substring(name,1,3) = ’abc’ -–name 以 abc 開頭的 id

select id from t where datediff(day,createdate,’2005-11-30′) = 0 -–‘2005-11-30’ –生成的 id

應改為:

select id from t where name like ‘abc%’

select id from t where createdate >= ‘2005-11-30’ and createdate < ‘2005-12-1’

6.在where子句中盡量避免使用!=或<>操作符,引擎會放棄使用索引而進行全表掃描。

SELECT * FROM employees WHERE name != 'jarye'

7.若中間索引列用到了范圍(>、

SELECT * FROM employees WHERE name= 'jarye' AND age = 22 AND position ='ceo';----索引生效

SELECT * FROM employees WHERE name= 'jarye' AND age > 22 AND position ='ceo';----索引position無效

8.like前面有%會失效,如果字段長的話,可以考慮使用全文檢索

Select * from dw_user where username like ‘%123%’——索引失效

Select * from dw_user where username like ‘%123’——索引失效

Select * from dw_user where username like ‘123%'——索引有效

9.在 where 子句中使用 or 來連接條件,必須全部索引存在才有效

如果一個字段有索引,一個字段沒有索引,將導致引擎放棄使用索引而進行全表掃描,如:

select id from t where num=10 or Name = ‘admin’

可以這樣查詢:

select id from t where num = 10

union all

select id from t where Name = ‘admin’

10.有 order by 的場景,請注意利用索引的有序性【阿里巴巴JAVA開發手冊】,參考order by中的單路和雙路排序算法原理

order by 最后的字段是組合索引的一部分,并且放在索引組合順序的最后,避免出現 file _ sort 的情況,影響查詢性能。

正例: where a =? and b =? order by c; 索引: a _ b _ c

反例:索引中有范圍查找,那么索引有序性無法利用,如: WHERE a >10 ORDER BY b; 索引a _ b 無法排序。

11.聯合索引,第一條件必須使用,且盡可能按索引順序執行

alter table dept add index my_ind (dname,loc);

select * from dept where dname=‘aaa’ and loc=‘aaa’———二個條件都使用了,索引生效

select * from dept where dname=‘aaa’——第一條件查詢,使用索引

select * from dept where loc=‘aaa’——沒有第一條件,不使用索引

建組合索引的時候,區分度最高的在最左邊。

正例:如果 where a =? and b =? , a 列的幾乎接近于唯一值,那么只需要單建 idx _ a 索引即可。

說明:存在非等號和等號混合判斷條件時,在建索引時,請把等號條件的列前置。如: where a >? and b =? 那么即使 a 的區分度更高,也必須把 b 放在索引的最前列。

聯合索引為什么需要遵循左前綴原則?

因為索引底層采用B+樹葉子節點順序排列,必須通過左前綴索引才能定位到具體的節點范圍。

12. 在where子句中使用參數,也會導致全表掃描,可以使用強制索引

因為SQL只有在運行時才會解析局部變量,但優化程序不能將訪問計劃的選擇推遲到運行時;它必須在編譯時進行選擇。然而,如果在編譯時建立訪問計劃,變量的值還是未知的,因而無法作為索引選擇的輸入項。如下面語句將進行全表掃描:

select id from t where num = @num

可以改為強制索引

select id from t with(index(索引名)) where num = @num

總結

以上是生活随笔為你收集整理的mysql 字符串索引 优化_MySQL性能优化之索引调优实战的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。