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

總結(jié)三道MySQL聯(lián)合索引面試題

 更新時間:2022年08月16日 10:17:00   作者:一燈架構(gòu)???????  
這篇文章主要介紹了總結(jié)三道MySQL聯(lián)合索引面試題,眾所周知MySQL聯(lián)合索引遵循最左前綴匹配原則,在少數(shù)情況下也會不遵循,創(chuàng)建聯(lián)合索引的時候,建議優(yōu)先把區(qū)分度高的字段放在第一列

前言:

眾所周知MySQL聯(lián)合索引遵循最左前綴匹配原則,在少數(shù)情況下也會不遵循(有興趣,可以翻一下上篇文章

創(chuàng)建聯(lián)合索引的時候,建議優(yōu)先把區(qū)分度高的字段放在第一列。

至于怎么統(tǒng)計區(qū)分度,可以按照下面這種方式。

創(chuàng)建一張測試表,用來測試:

CREATE TABLE `test` (
  `id` int NOT NULL AUTO_INCREMENT COMMENT '主鍵',
  `a` int NOT NULL,
  `b` int NOT NULL,
  `c` int NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB COMMENT='測試表';

統(tǒng)計每個字段的區(qū)分度:

select 
    count(distinct a)/count(*), 
    count(distinct b)/count(*),
    count(distinct c)/count(*)
from test;

值越大,區(qū)分度越高,優(yōu)先放在第一列。

很多人不知道聯(lián)合索引在B+樹中是怎么存儲的?我簡單畫一下。

比如在(a,b)字段上面創(chuàng)建聯(lián)合索引,存儲結(jié)構(gòu)類似下面這樣:

image.png

葉子節(jié)點存儲全部數(shù)據(jù),用雙鏈表指針相連,數(shù)據(jù)都是先按a字段排序,a字段的值相等時再按b字段排序。

a字段的值是全局有序的,分別有1,1,1,2,2,2。

b字段的值是全局無序的,分別有1,3,5,1,3,5,只有在a字段的值相等時才呈現(xiàn)出局部有序。

所以在進行SQL查詢的時候,如果where條件中沒有a字段,只有b字段,是無法用到索引的,像下面這樣:

select * from test where b=1;

像有些文章上面說的,在(a,b)兩個字段上創(chuàng)建聯(lián)合索引,就會創(chuàng)建兩個索引,分別是(a)和(a,b),這其實是一種不恰當?shù)谋硎?,雖然結(jié)果是對的。

下面做幾道聯(lián)合索引的經(jīng)典面試題,試一下大家掌握的怎么樣?

第一題:

下面這條SQL,該怎么創(chuàng)建聯(lián)合索引?

SELECT * FROM test WHERE a = 1 and b = 1 and c = 1;

你以為的答案是(a,b,c),其實答案是6個,abc三個的排列組合,(a,b,c)、(a,c,b)、(b,a,c)、(b,c,a)、(c,a,b)、(c,b,a)。

MySQL優(yōu)化器為了適應(yīng)索引,會調(diào)整條件的順序。

再給面試官補充一句,區(qū)分度高的字段放在最前面,大大加分。

第二題:

下面這條SQL,該怎么創(chuàng)建聯(lián)合索引?

SELECT * FROM test WHERE a = 1 and b > 1 and c = 1;

考察的知識點是: 聯(lián)合索引遇到范圍匹配會停止,不會再匹配后面的索引字段。

所以答案應(yīng)該是:(a,c,b)和 (c,a,b)。

當創(chuàng)建(a,c,b)和 (c,a,b)索引的時候,查詢會用到3個字段的索引,效率更高。

怎么判斷是用到了3個字段的索引,而不是只用到前兩個字段的索引呢?

有個非常簡單的方法,看執(zhí)行計劃的索引長度。

由于int類型的字段占4個字節(jié),3個字段長度剛好是12個字節(jié)。

第三題:

下面這條SQL,該怎么創(chuàng)建聯(lián)合索引

SELECT * FROM test WHERE a in (1,2,3) and b > 1;

答案是(a,b)。in條件查詢會被轉(zhuǎn)換成等值查詢,可以驗證一下:

可以看到用到了兩個字段的索引。

所以我們在平時做開發(fā),盡量想辦法把范圍查詢轉(zhuǎn)換成in條件查詢,效率更高。

到此這篇關(guān)于總結(jié)三道MySQL聯(lián)合索引面試題的文章就介紹到這了,更多相關(guān)MySQL聯(lián)合索引內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • getdata table表格數(shù)據(jù)join mysql方法

    getdata table表格數(shù)據(jù)join mysql方法

    今天小編就為大家分享一篇關(guān)于getdata table表格數(shù)據(jù)join mysql方法,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-02-02
  • MySQL Innodb關(guān)鍵特性之插入緩沖(insert buffer)

    MySQL Innodb關(guān)鍵特性之插入緩沖(insert buffer)

    這篇文章主要介紹了MySQL Innodb關(guān)鍵特性之插入緩沖的相關(guān)資料,幫助大家更好的理解和學習使用Innodb存儲引擎,感興趣的朋友可以了解下
    2021-04-04
  • ?SQL 中 CASE 表達式的使用方式

    ?SQL 中 CASE 表達式的使用方式

    這篇文章主要介紹了?SQL 中 CASE 表達式的使用方式,文章通過圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-09-09
  • PHP函數(shù)使用說明(補充)

    PHP函數(shù)使用說明(補充)

    PHP函數(shù)使用說明,應(yīng)用舉例,精簡點評,希望對您學習php有所幫助。
    2010-07-07
  • lnmp下如何關(guān)閉Mysql日志保護磁盤空間

    lnmp下如何關(guān)閉Mysql日志保護磁盤空間

    這篇文章主要介紹了lnmp下如何關(guān)閉Mysql日志保護磁盤空間的相關(guān)資料,需要的朋友可以參考下
    2015-09-09
  • 查詢MySQL中的樹型表兩種方法

    查詢MySQL中的樹型表兩種方法

    在 MySQL中查詢樹型表(即具有層級結(jié)構(gòu)的表)可以使用遞歸查詢或者使用嵌套集模型,下面介紹兩種方法查詢MySQL中的樹型表,感興趣的朋友一起看看吧
    2024-01-01
  • MySQL中表復制:create table like 與 create table as select

    MySQL中表復制:create table like 與 create table as select

    這篇文章主要介紹了MySQL中表復制:create table like 與 create table as select,需要的朋友可以參考下
    2014-12-12
  • MySQL使用正則表達式去檢索指定數(shù)據(jù)庫字段

    MySQL使用正則表達式去檢索指定數(shù)據(jù)庫字段

    這篇文章主要介紹了MySQL使用正則表達式去檢索指定數(shù)據(jù)庫字段,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-09-09
  • MySQL中的基本查詢語句學習筆記

    MySQL中的基本查詢語句學習筆記

    這篇文章主要介紹了MySQL中的基本查詢語句學習筆記,包括使用limit限制查詢結(jié)果條數(shù)和合并查詢結(jié)果的方法,需要的朋友可以參考下
    2016-03-03
  • MySQL?條件查詢詳解

    MySQL?條件查詢詳解

    這篇文章主要介紹了MySQL條件查詢,本文通過示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-05-05

最新評論