欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL索引失效的原因及問題排查

 更新時間:2024年04月26日 10:40:18   作者:山腳ice  
MySQL索引失效是指在查詢數(shù)據(jù)時,MySQL數(shù)據(jù)庫無法有效地使用索引來提高查詢性能,導(dǎo)致查詢速度變慢或者索引無效的情況,本文給大家介紹了MySQL中什么情況下會出現(xiàn)索引失效?以及如何排查索引失效?,需要的朋友可以參考下

1-引言:什么是MySQL的索引失效?(What、Why)

1-1 索引失效定義

  • 在MySQL中,索引是用來加快檢索數(shù)據(jù)庫記錄的一種數(shù)據(jù)結(jié)構(gòu)。
  • 索引失效指的是在進(jìn)行查詢操作時,本應(yīng)該使用索引來提升查詢效率的場景下,數(shù)據(jù)庫沒有利用索引,而是采用了全表掃描的方式,這會大大增加查詢時間和系統(tǒng)負(fù)擔(dān)。

1-2 為什么排查索引失效

排查索引失效的原因是至關(guān)重要的,主要有以下方面:

  • 1. 提高查詢效率:索引的主要目的是加快數(shù)據(jù)檢索速度。當(dāng)索引失效時,數(shù)據(jù)庫系統(tǒng)可能退回到更慢的查詢方法,如全表掃描,這會顯著增加查詢時間和降低整體性能。
  • 2. 降低服務(wù)器負(fù)載:使用索引可以顯著減少數(shù)據(jù)庫處理查詢所需處理的數(shù)據(jù)量,從而減少CPU使用率和IO讀寫。如果索引失效,數(shù)據(jù)庫必須加載更多數(shù)據(jù),這會增加服務(wù)器的負(fù)載和資源消耗。

2- 索引失效的原因及排查(How)

2-1 索引失效的情況

  • 以以下的學(xué)生信息表舉例
CREATE TABLE `student_info` (
  `student_id` int(11) NOT NULL AUTO_INCREMENT,
  `student_name` varchar(50) NOT NULL,
  `student_age` int(11) DEFAULT NULL,
  `enrollment_date` datetime DEFAULT NULL,
  PRIMARY KEY (`student_id`),
  UNIQUE KEY `student_name` (`student_name`),
  KEY `student_age` (`student_age`),
  KEY `enrollment_date` (`enrollment_date`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
  • 表的索引情況:
  • 總結(jié)來說,表 student_info 有四個字段上定義了索引:
    • 一個主鍵索引 student_id
    • 一個唯一索引 student_name
    • 以及兩個普通索引 student_age 和 enrollment_date。

image.png

① 索引列參與計(jì)算

  • 正常的通過 age 去做查詢
    • 走的是 student_age 的索引
explain select * from student_info where student_age=21;

image.png

  • 如果索引列參與了計(jì)算進(jìn)行查詢
    • 索引失效
explain select * from student_info where student_age+1 =21;

image.png

  • 如果不是對列進(jìn)行計(jì)算,而是對列等號右側(cè)的值進(jìn)行計(jì)算,結(jié)果還是走索引的。

image.png

② 對索引列進(jìn)行函數(shù)操作

  • 正常的查詢——>走索引
explain select * from student_info where enrollment_date = '2022-09-04 08:00:00';

image.png

  • 如果對查詢的字段加上函數(shù)操作時,索引失效
explain select * from student_info where YEAR(enrollment_date) = 2022;

image.png

③ 查詢中使用了 OR 兩邊有范圍查詢 > 或 <

  • 正常情況查詢,查詢使用 student_name 索引
explain select * from student_info where student_name='Helen' and student_age>15;

image.png

  • 如果使用了 OR 進(jìn)行查詢,兩邊包含范圍查詢 > 或 <
    • 此時索引失效
explain select * from student_info where student_name='Helen' or student_age>15;

image.png

  • 如果沒有范圍查詢下使用 OR 還是正常走索引
explain select * from student_info where student_name='Helen' or student_age=18;

image.png

④ like 操作:以 % 開頭的 like 查詢

  • 以 % 開頭的 LIKE 查詢比如 LIKE ‘%abc’;;

⑤ 不等于比較 !=

  • 在MySQL中 != 比較有可能會導(dǎo)致不走索引,但如果對 id 進(jìn)行 != 比較,是有可能走索引的。
  • != 比較是否走索引,與索引的選擇、數(shù)據(jù)分布情況有關(guān),不單是由于查詢包含 != 而引起的。

⑥ order by

  • 如果使用 order by 時,表中的數(shù)據(jù)量很小,數(shù)據(jù)庫會直接在內(nèi)存中進(jìn)行排序,而不使用索引

image.png

⑦ 使用 IN

  • 使用 IN 的時候,有可能走索引,也有可能不走索引。當(dāng)在 IN 的取值范圍比較大的時候有可能會導(dǎo)致索引失效,走全表掃描(NOT IN 和 IN的失效場景相同)。

2-2 索引失效的排查

使用 explain 排查

  • 和 MySQL 慢查詢的排查類似,使用 Explain 語句來進(jìn)行排查。

需要關(guān)注的字段:type、key、extra

  • 我們可以根據(jù) key、type、extra 來判斷一條語句是否走了索引。
  • 一般走索引的情況 :
    • key 值不為 null
    • type 值應(yīng)該為 ref、eq_ref、range、const 這幾個
    • extra 的話如果是 NULL,或者 using indedx,using index condition 都是可以的

索引失效情況

  • 如果一條語句出現(xiàn)了 type 值為 all、key 為 null,extra = Using where 此時是索引失效了

此時就需要排查索引失效的原因

  • 索引是否符合最左前綴匹配

  • 查詢語句出現(xiàn)以上 7 種情況

3- 總結(jié):索引失效知識點(diǎn)小結(jié)

MySQL中什么情況下會出現(xiàn)索引失效?如何排查索引失效?
回答
:::info
MySQL中索引失效的情況有

    1. 比如聯(lián)合索引在查詢的過程中不符合最左前綴原則,此時聯(lián)合索引會失效
    1. 查詢的語句 索引列 進(jìn)行計(jì)算,此時會使得索引失效
    1. 查詢的語句 對索引列進(jìn)行了函數(shù)操作,比如利用了 **YEAR()** 函數(shù)
    1. 查詢語句中 包含 **OR** ,且 OR 兩側(cè)有范圍查詢 也就是 **>** 或 **<** 此時索引會失效
    1. 查詢語句中 使用了 **like** 且 **like** 中存在 以**%** 開頭的匹配,此時索引會失效
    1. 查詢語句中 使用了 **!=** 進(jìn)行比較,但這種情況也和數(shù)據(jù)的分布情況有關(guān)系,
    1. 當(dāng)數(shù)據(jù)表中的數(shù)據(jù)較少,使用 **order by** 的時候,可能會不走索引直接在內(nèi)存中進(jìn)行排序
    1. 當(dāng)使用 **IN**** **時候取值范圍比較大的時候有可能會導(dǎo)致索引失效

索引失效的排查

  • ① 使用 Explain 對 SQL 語句進(jìn)行排查
  • 需要 關(guān)注的字段有 **type****key**、**extra**
  • 如果一條語句出現(xiàn)了 type 值為 all、key 為 nullextra = Using where 此時是索引失效了

此時就需要排查索引失效的原因,是否存在以上情況

以上就是MySQL索引失效的原因及問題排查的詳細(xì)內(nèi)容,更多關(guān)于MySQL索引失效的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • MySQL筆記之子查詢使用介紹

    MySQL筆記之子查詢使用介紹

    子查詢是將一個查詢語句嵌套在另一個查詢語句中,內(nèi)層查詢語句的查詢結(jié)果,可以為外層查詢語句提供查詢條件
    2013-05-05
  • Mysql 遠(yuǎn)程連接配置實(shí)現(xiàn)的兩種方法

    Mysql 遠(yuǎn)程連接配置實(shí)現(xiàn)的兩種方法

    這篇文章主要介紹了Mysql 遠(yuǎn)程連接配置實(shí)現(xiàn)的兩種方法的相關(guān)資料,需要的朋友可以參考下
    2017-07-07
  • 詳解MySQL中的分組查詢與連接查詢語句

    詳解MySQL中的分組查詢與連接查詢語句

    這篇文章主要介紹了MySQL中的分組查詢與連接查詢語句,同時還介紹了一些統(tǒng)計(jì)函數(shù)的用法,需要的朋友可以參考下
    2016-03-03
  • mysql實(shí)現(xiàn)自增序列的示例代碼

    mysql實(shí)現(xiàn)自增序列的示例代碼

    這篇文章主要介紹了mysql實(shí)現(xiàn)自增序列的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-02-02
  • MySQL 正則表達(dá)式用法、模式和注意事項(xiàng)詳解

    MySQL 正則表達(dá)式用法、模式和注意事項(xiàng)詳解

    MySQL正則表達(dá)式通過REGEXP/RLIKE操作符實(shí)現(xiàn)模式匹配,支持元字符、字符類、量詞等基本功能,8.0+版本新增REGEXP_LIKE等函數(shù),提供更強(qiáng)大的文本處理能力,使用時需注意大小寫、性能及版本兼容性,本文介紹MySQL 正則表達(dá)式詳細(xì)說明,感興趣的朋友一起看看吧
    2025-08-08
  • 通過唯一索引S鎖與X鎖來了解MySQL死鎖套路

    通過唯一索引S鎖與X鎖來了解MySQL死鎖套路

    毫不夸張的說,有一半以上的死鎖問題由唯一索引貢獻(xiàn),后面介紹的很多死鎖的問題都跟唯一索引有關(guān)。這次我們講一段唯一索引 S 鎖與 X 鎖的案例,下面小編來和大家一起學(xué)習(xí)一下
    2019-05-05
  • MySQL?緩存機(jī)制與架構(gòu)解析(最新推薦)

    MySQL?緩存機(jī)制與架構(gòu)解析(最新推薦)

    本文詳細(xì)介紹了MySQL的緩存機(jī)制和整體架構(gòu),包括一級緩存(InnoDB?Buffer?Pool)和二級緩存(Query?Cache),文章還探討了SQL查詢執(zhí)行全流程,并分析了MySQL?8.0移除查詢緩存的原因,最后,提出了應(yīng)用層緩存和InnoDB緩沖池優(yōu)化的建議,感興趣的朋友跟隨小編一起看看吧
    2025-02-02
  • mysql如何修改表中某個數(shù)據(jù)

    mysql如何修改表中某個數(shù)據(jù)

    這篇文章主要介紹了mysql如何修改表中某個數(shù)據(jù)的實(shí)現(xiàn)方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-08-08
  • MySql添加新用戶及為用戶創(chuàng)建數(shù)據(jù)庫和給用戶分配權(quán)限方法介紹

    MySql添加新用戶及為用戶創(chuàng)建數(shù)據(jù)庫和給用戶分配權(quán)限方法介紹

    這篇文章主要介紹了MySql添加新用戶及為用戶創(chuàng)建數(shù)據(jù)庫和給用戶分配權(quán)限方法介紹,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-08-08
  • Mysql LONGBLOB 類型存儲二進(jìn)制數(shù)據(jù) (修改+調(diào)試+整理)

    Mysql LONGBLOB 類型存儲二進(jìn)制數(shù)據(jù) (修改+調(diào)試+整理)

    代碼來自網(wǎng)絡(luò),我學(xué)習(xí)整理了一下,測試通過,下面的參數(shù)需要設(shè)置為你自己的
    2009-07-07

最新評論