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

哪些情況會導(dǎo)致?MySQL?索引失效

 更新時間:2022年07月05日 10:04:14   作者:??Java中文社群????  
這篇文章主要介紹了哪些情況會導(dǎo)致MySQL索引失效,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價值,需要的朋友可以參考一下

前言

為了驗(yàn)證 MySQL 中哪些情況下會導(dǎo)致索引失效,我們可以借助 explain 執(zhí)行計劃來分析索引失效的具體場景。

explain 使用如下,只需要在查詢的 SQL 前面添加上 explain 關(guān)鍵字即可,如下圖所示: 

 而以上查詢結(jié)果的列中,我們最主要觀察 key 這一列,key 這一列表示實(shí)際使用的索引,如果為 NULL 則表示未使用索引,反之則使用了索引。

以上所有結(jié)果列說明如下:

  • id — 選擇標(biāo)識符,id 越大優(yōu)先級越高,越先被執(zhí)行;
  • select_type — 表示查詢的類型;
  • table — 輸出結(jié)果集的表;
  • partitions — 匹配的分區(qū);
  • type — 表示表的連接類型;
  • possible_keys — 表示查詢時,可能使用的索引;
  • key — 表示實(shí)際使用的索引;
  • key_len — 索引字段的長度;
  • ref— 列與索引的比較;
  • rows — 大概估算的行數(shù);
  • filtered — 按表?xiàng)l件過濾的行百分比;
  • Extra — 執(zhí)行情況的描述和說明。

其中最重要的就是 type 字段,type 值類型如下:

  • all — 掃描全表數(shù)據(jù);
  • index — 遍歷索引;
  • range — 索引范圍查找;
  • index_subquery — 在子查詢中使用 ref;
  • unique_subquery — 在子查詢中使用 eq_ref;
  • ref_or_null — 對 null 進(jìn)行索引的優(yōu)化的 ref;
  • fulltext — 使用全文索引;
  • ref — 使用非唯一索引查找數(shù)據(jù);
  • eq_ref — 在 join 查詢中使用主鍵或唯一索引關(guān)聯(lián);

const — 將一個主鍵放置到 where 后面作為條件查詢, MySQL 優(yōu)化器就能把這次查詢優(yōu)化轉(zhuǎn)化為一個常量,如何轉(zhuǎn)化以及何時轉(zhuǎn)化,這個取決于優(yōu)化器,這個比 eq_ref 效率高一點(diǎn)。

創(chuàng)建測試表和數(shù)據(jù)

為了演示和測試那種情況下會導(dǎo)致索引失效,我們先創(chuàng)建一個測試表和相應(yīng)的數(shù)據(jù):

-- 創(chuàng)建表
drop table if exists student;
create table student(
  id int primary key auto_increment comment '主鍵',
  sn varchar(32) comment '學(xué)號',
  name varchar(250) comment '姓名',
  age int comment '年齡',
  sex bit comment '性別',
  address varchar(250) comment '家庭地址',
  key idx_address (address),
  key idx_sn_name_age (sn,name,age)
)ENGINE=InnoDB DEFAULT CHARSET=utf8;
-- 添加測試數(shù)據(jù)
insert into student(id,sn,name,age,sex,address)
  values(1,'cn001','張三',18,1,'高老莊'),
  (2,'cn002','李四',20,0,'花果山'),
  (3,'cn003','王五',50,1,'水簾洞');

當(dāng)前表中總共有 3 個索引,如下圖所示: 

PS:本文以下內(nèi)容基于 MySQL 5.7 InnoDB 數(shù)據(jù)引擎下。

索引失效情況1:非最左匹配

最左匹配原則指的是,以最左邊的為起點(diǎn)字段查詢可以使用聯(lián)合索引,否則將不能使用聯(lián)合索引。 我們本文的聯(lián)合索引的字段順序是 sn + name + age,我們假設(shè)它們的順序是 A + B + C,以下聯(lián)合索引的使用情況如下: 

 從上述結(jié)果可以看出,如果是以最左邊開始匹配的字段都可以使用上聯(lián)合索引,比如:

  • A+B+C
  • A+B
  • A+C

其中:A 等于字段 sn,B 等于字段 name,C 等于字段 age。

而 B+C 卻不能使用到聯(lián)合索引,這就是最左匹配原則。

索引失效情況2:錯誤模糊查詢

模糊查詢 like 的常見用法有 3 種:

  • 模糊匹配后面任意字符:like '張%'
  • 模糊匹配前面任意字符:like '%張'
  • 模糊匹配前后任意字符:like '%張%'

而這 3 種模糊查詢中只有第 1 種查詢方式可以使用到索引,具體執(zhí)行結(jié)果如下: 

索引失效情況3:列運(yùn)算

如果索引列使用了運(yùn)算,那么索引也會失效,如下圖所示: 

索引失效情況4:使用函數(shù)

查詢列如果使用任意 MySQL 提供的函數(shù)就會導(dǎo)致索引失效,比如以下列使用了 ifnull 函數(shù)之后的執(zhí)行計劃如下: 

索引失效情況5:類型轉(zhuǎn)換

如果索引列存在類型轉(zhuǎn)換,那么也不會走索引,比如 address 為字符串類型,而查詢的時候設(shè)置了 int 類型的值就會導(dǎo)致索引失效,

如下圖所示: 

索引失效情況6:使用 is not null

當(dāng)在查詢中使用了 is not null 也會導(dǎo)致索引失效,而 is null 則會正常觸發(fā)索引的,

如下圖所示: 

總結(jié)

導(dǎo)致 MySQL 索引失效的常見場景有以下 6 種:

  • 聯(lián)合索引不滿足最左匹配原則。
  • 模糊查詢最前面的為不確定匹配字符。
  • 索引列參與了運(yùn)算。
  • 索引列使用了函數(shù)。
  • 索引列存在類型轉(zhuǎn)換。
  • 索引列使用 is not null 查詢。

到此這篇關(guān)于哪些情況會導(dǎo)致 MySQL 索引失效的文章就介紹到這了,更多相關(guān)MySQL 索引失效內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 在MySQL?8.0版本中開啟遠(yuǎn)程登錄詳細(xì)的操作步驟

    在MySQL?8.0版本中開啟遠(yuǎn)程登錄詳細(xì)的操作步驟

    有時數(shù)據(jù)庫所在機(jī)器與項(xiàng)目運(yùn)行的機(jī)器不是同一個,那么就涉及到遠(yuǎn)程鏈接數(shù)據(jù)庫了,下面這篇文章主要給大家介紹了關(guān)于在MySQL?8.0版本中開啟遠(yuǎn)程登錄詳細(xì)的操作步驟,需要的朋友可以參考下
    2024-04-04
  • MySQL常見故障與優(yōu)化方式

    MySQL常見故障與優(yōu)化方式

    這篇文章主要介紹了MySQL常見故障與優(yōu)化方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教<BR>
    2024-04-04
  • 教你一招永久解決mysql插入中文失敗問題

    教你一招永久解決mysql插入中文失敗問題

    mysql經(jīng)常會遇到某些中文插入異常,最近有同學(xué)反饋了這樣一個問題,所以下面這篇文章主要給大家介紹了關(guān)于如何永久解決mysql插入中文失敗問題的相關(guān)資料,需要的朋友可以參考下
    2021-11-11
  • 使用MySQL的yum源安裝MySQL5.7數(shù)據(jù)庫的方法

    使用MySQL的yum源安裝MySQL5.7數(shù)據(jù)庫的方法

    這篇文章主要介紹了使用MySQL的yum源安裝MySQL5.7數(shù)據(jù)庫的方法的相關(guān)資料,需要的朋友可以參考下
    2016-08-08
  • MySQL高級查詢語法分析

    MySQL高級查詢語法分析

    在面試過程中經(jīng)常會遇到sq查詢問題,今天小編通過本文給大家介紹下MySQL高級查詢語法分析,感興趣的朋友跟隨小編一起看看吧
    2022-02-02
  • 在MySQL中存儲圖片的操作步驟

    在MySQL中存儲圖片的操作步驟

    之前遇到一個問題,就是在將項(xiàng)目遷移到別的服務(wù)器的時候出現(xiàn)圖片路徑不對的問題,因?yàn)榇娣艌D片的方式是在數(shù)據(jù)庫中存放圖片路徑,但是路徑前卻帶了域名,所以本文將給大家介紹在MySQL中存儲圖片的操作步驟,需要的朋友可以參考下
    2024-04-04
  • mysqlhotcopy 正則使用小技巧

    mysqlhotcopy 正則使用小技巧

    mysqlhotcopy 是MySQL的熱備工具,詳細(xì)請看手冊 ,為了安全起見我們給熱備分配個用戶
    2011-08-08
  • MySQL?中字符集詳細(xì)介紹

    MySQL?中字符集詳細(xì)介紹

    這篇文章主要介紹了MySQL?中字符集詳細(xì)介紹,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-08-08
  • MySQL如何處理InnoDB并發(fā)事務(wù)中的間隙鎖死鎖

    MySQL如何處理InnoDB并發(fā)事務(wù)中的間隙鎖死鎖

    這篇文章主要為大家介紹了MySQL如何處理InnoDB并發(fā)事務(wù)中的間隙鎖死鎖,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-10-10
  • mysql 5.7.23 winx64解壓版安裝教程

    mysql 5.7.23 winx64解壓版安裝教程

    這篇文章主要為大家詳細(xì)介紹了mysql 5.7.23 winx64解壓版安裝教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-09-09

最新評論