成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

索引失效底層原理分析,這么多年終于有人講清楚了

數(shù)據(jù)庫 MySQL
今天我們講講MySQL索引為什么會失效,很多文章和培訓(xùn)機(jī)構(gòu)的教程,都只會告訴你,在什么情況下索引會失效。

前言

吊打面試官又來啦,今天我們講講MySQL索引為什么會失效,很多文章和培訓(xùn)機(jī)構(gòu)的教程,都只會告訴你,在什么情況下索引會失效。

比如:沒遵循最佳左前綴法則、范圍查詢的右邊會失效、like查詢用不到索引等等

但是沒有一個人告訴你,索引失效的原理是什么,老哥今天就告訴大家,讓你們知其然,還要知其所以然。

單值索引B+樹圖

單值索引在B+樹的結(jié)構(gòu)里,一個節(jié)點(diǎn)只存一個鍵值對

聯(lián)合索引

開局一張圖,由數(shù)據(jù)庫的a字段和b字段組成一個聯(lián)合索引。

從本質(zhì)上來說,聯(lián)合索引也是一個B+樹,和單值索引不同的是,聯(lián)合索引的鍵值對不是1,而是大于1個。

a, b 排序分析

a順序:1,1,2,2,3,3

b順序:1,2,1,4,1,2

大家可以發(fā)現(xiàn)a字段是有序排列,b字段是無序排列(因為B+樹只能選一個字段來構(gòu)建有序的樹)

一不小心又會發(fā)現(xiàn),在a相等的情況下,b字段是有序的。

大家想想平時編程中我們要對兩個字段排序,是不是先按照第一個字段排序,如果第一個字段出現(xiàn)相等的情況,就用第二個字段排序。這個排序方式同樣被用到了B+樹里。

分析最佳左前綴原理

先舉一個遵循最佳左前綴法則的例子 

  1. select * from testTable where a=1 and b=2 

分析如下:

首先a字段在B+樹上是有序的,所以我們可以通過二分查找法來定位到a=1的位置。

其次在a確定的情況下,b是相對有序的,因為有序,所以同樣可以通過二分查找法找到b=2的位置。

再來看看不遵循最佳左前綴的例子 

  1. select * from testTable where b=2 

分析如下:

我們來回想一下b有順序的前提:在a確定的情況下。

現(xiàn)在你的a都飛了,那b肯定是不能確定順序的,在一個無序的B+樹上是無法用二分查找來定位到b字段的。

所以這個時候,是用不上索引的。大家懂了嗎?

[[346781]]

范圍查詢右邊失效原理

舉例 

  1. select * from testTable where a>1 and b=2 

分析如下:

首先a字段在B+樹上是有序的,所以可以用二分查找法定位到1,然后將所有大于1的數(shù)據(jù)取出來,a可以用到索引。

b有序的前提是a是確定的值,那么現(xiàn)在a的值是取大于1的,可能有10個大于1的a,也可能有一百個a。

大于1的a那部分的B+樹里,b字段是無序的(開局一張圖),所以b不能在無序的B+樹里用二分查找來查詢,b用不到索引。

like索引失效原理 

  1. where name like "a%"  
  2. where name like "%a%"  
  3. where name like "%a" 

我們先來了解一下%的用途

  •  %放在右邊,代表查詢以"a"開頭的數(shù)據(jù),如:abc
  •  兩個%%,代表查詢數(shù)據(jù)中包含"a"的數(shù)據(jù),如:cab、cba、abc
  •  %放在左邊,代表查詢以"a"為結(jié)尾的數(shù)據(jù),如cba

為什么%放在右邊有時候能用到索引

  •  %放右邊叫做:前綴
  •  %%叫做:中綴
  •  %放在左邊叫做:后綴

沒錯,這里依然是最佳左前綴法則這個概念

大家可以看到,上面的B+樹是由字符串組成的。

字符串的排序方式:先按照第一個字母排序,如果第一個字母相同,就按照第二個字母排序。。。以此類推

開始分析

一、%號放右邊(前綴)

由于B+樹的索引順序,是按照首字母的大小進(jìn)行排序,前綴匹配又是匹配首字母。所以可以在B+樹上進(jìn)行有序的查找,查找首字母符合要求的數(shù)據(jù)。所以有些時候可以用到索引。

二、%號放左邊

是匹配字符串尾部的數(shù)據(jù),我們上面說了排序規(guī)則,尾部的字母是沒有順序的,所以不能按照索引順序查詢,就用不到索引。

三、兩個%%號

這個是查詢?nèi)我馕恢玫淖帜笣M足條件即可,只有首字母是進(jìn)行索引排序的,其他位置的字母都是相對無序的,所以查找任意位置的字母是用不上索引的。

總結(jié)

這里把一些經(jīng)典的索引失效案例給大家分析了,希望能引發(fā)大家的思考,能夠通過這些案例,明白其他情況索引失效的原理。

之后我們在講講,如何通過索引查詢到數(shù)據(jù)整個流程,InnoDB和MyISAM兩個引擎底層索引的實現(xiàn)區(qū)別。

授人以魚不如授人以漁,這一瞬間,老哥感覺自己特別的shuai。 

 

責(zé)任編輯:龐桂玉 來源: segmentfault
相關(guān)推薦

2019-07-07 08:18:10

MySQL索引數(shù)據(jù)庫

2020-07-29 09:21:34

Docker集群部署隔離環(huán)境

2021-07-05 22:22:24

協(xié)議MQTT

2020-12-24 15:18:27

大數(shù)據(jù)數(shù)據(jù)分析

2024-04-01 10:09:23

AutowiredSpring容器

2021-04-10 10:37:04

OSITCP互聯(lián)網(wǎng)

2023-08-14 11:35:16

流程式轉(zhuǎn)化率數(shù)據(jù)指標(biāo)

2024-02-23 08:08:21

2022-01-05 09:27:24

讀擴(kuò)散寫擴(kuò)散feed

2021-01-29 10:50:04

數(shù)據(jù)中臺數(shù)據(jù)數(shù)據(jù)管理

2020-03-30 16:18:02

代碼開發(fā)工具

2019-05-22 08:43:45

指令集RISC-V開源

2020-04-23 10:21:57

Linux 網(wǎng)絡(luò)編程 數(shù)據(jù)

2021-04-21 10:00:08

MySQL索引數(shù)據(jù)庫

2024-02-27 14:27:16

2022-07-04 11:27:02

標(biāo)簽數(shù)據(jù)指標(biāo)標(biāo)簽體系

2024-01-05 07:55:39

Linux虛擬內(nèi)存

2023-05-29 13:59:00

GPTOpenAI監(jiān)督微調(diào)

2021-09-21 16:18:07

手機(jī)電池快充

2019-06-19 14:58:38

服務(wù)器負(fù)載均衡客戶端
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 国产精品久久久久久久7777 | 久久av在线播放 | 久草新在线 | 欧美一级观看 | 成人在线小视频 | 亚洲一区二区三区在线 | 亚洲高清视频一区 | 欧美日韩亚洲一区 | 久久久久9999 | 国产高清精品一区二区三区 | 国产视频精品免费 | 91影院| 成人国产综合 | 一区中文字幕 | 91精品国产91综合久久蜜臀 | 久久久久久久久99精品 | 久久免费国产 | av超碰| 亚洲精选久久 | 精品一区二区三区四区外站 | 成人免费在线 | 成人免费淫片aa视频免费 | 男女网站免费观看 | 可以在线观看av的网站 | 亚洲五码在线 | www精品美女久久久tv | av手机免费在线观看 | 久久久久久久一级 | 中文字幕一区二区三区四区 | av日韩一区| 欧美激情国产日韩精品一区18 | 日韩精品在线观看一区二区三区 | 国产精品不卡一区 | 激情黄色在线观看 | 国产精品看片 | 黄色在线免费观看 | 国产精品网址 | 欧美激情五月 | 国产一级片91| 久久国产成人 | 久久精品国产免费一区二区三区 |