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

一文搞懂什么是MySQL前綴索引

 更新時間:2022年09月29日 08:22:25   作者:鴨血粉絲Tang  
所謂前綴索引,說白了就是對文本的前幾個字符建立索引,有點類似于?Oracle?中對字段使用?Left?函數(shù)來建立函數(shù)索引,只不過?MySQL?的這個前綴索引在查詢時是內(nèi)部自動完成匹配的。本文將通過示例詳細(xì)聊聊前綴索引,需要的可以參考一下

一、什么是前綴索引

所謂前綴索引,說白了就是對文本的前幾個字符建立索引(具體是幾個字符在建立索引時去指定),比如以產(chǎn)品名稱的前 10 位來建索引,這樣建立起來的索引更小,查詢效率更快!

有點類似于 Oracle 中對字段使用 Left 函數(shù)來建立函數(shù)索引,只不過 MySQL 的這個前綴索引在查詢時是內(nèi)部自動完成匹配的,并不需要使用 Left 函數(shù)。

二、為什么要用前綴索引

可能有的同學(xué)會發(fā)出疑問,為什么不對整個字段建立索引呢?

一般來說,當(dāng)某個字段的數(shù)據(jù)量太大,而且查詢又非常的頻繁時,使用前綴索引能有效的減小索引文件的大小,讓每個索引頁可以保存更多的索引值,從而提高了索引查詢的速度。

比如,客戶店鋪名稱,有的名稱很長,有的很短,如果完全按照全覆蓋來建索引,索引的存儲空間可能會非常的大,有的表如果索引創(chuàng)建的很多,甚至?xí)霈F(xiàn)索引存儲的空間都比數(shù)據(jù)表的存儲空間大很多,因此對于這種文本很長的字段,我們可以截取前幾個字符來建索引,在一定程度上,既能滿足數(shù)據(jù)的查詢效率要求,又能節(jié)省索引存儲空間。

但是另一方面,前綴索引也有它的缺點,MySQL 中無法使用前綴索引進(jìn)行 ORDER BY 和 GROUP BY,也無法用來進(jìn)行覆蓋掃描,當(dāng)字符串本身可能比較長,而且前幾個字符完全相同,這個時候前綴索引的優(yōu)勢已經(jīng)不明顯了,就沒有創(chuàng)建前綴索引的必要了。

因此這又回到一個概念,那就是關(guān)于索引的選擇性

關(guān)于數(shù)據(jù)庫表索引的選擇性,我會單獨開篇來講解,大家只需要記住一點:索引的選擇性越高則查詢效率越高,因為選擇性高的索引可以讓 MySQL 在查找時過濾掉更多的行,數(shù)據(jù)查詢速度更快!

當(dāng)某個字段內(nèi)容的前幾位區(qū)分度很高的時候,這個時候采用前綴索引,可以在查詢性能和空間存儲方面達(dá)到一個很高的性價比。

那么問題來了,怎么創(chuàng)建前綴索引呢?

三、怎么創(chuàng)建前綴索引

建立前綴索引的方式,方法很簡單,通過如下方式即可創(chuàng)建!

ALTER?TABLE?table_name?ADD?KEY(column_name(prefix_length));

其中prefix_length這個參數(shù),就是前綴長度的意思,通常通過如下方式進(jìn)行確認(rèn),步驟如下:

第一步,先計算某字段全列的區(qū)分度。

SELECT?COUNT(DISTINCT?column_name)?/?COUNT(*)?FROM?table_name;

第二步,然后再計算前綴長度為多少時和全列的區(qū)分度最相似

SELECT?COUNT(DISTINCT?LEFT(column_name,?prefix_length))?/?COUNT(*)?FROM?table_name;

最后,不斷地調(diào)整prefix_length的值,直到和全列計算出區(qū)分度相近,最相近的那個值,就是我們想要的值。

下面以某個測試表為例,數(shù)據(jù)體量在 100 萬以上,表結(jié)構(gòu)如下!

CREATE?TABLE?`tb_test`?(
??`id`?bigint(20)?unsigned?NOT?NULL?AUTO_INCREMENT,
??`name`?varchar(100)?DEFAULT?NULL,
??PRIMARY?KEY?(`id`)
)?ENGINE=InnoDB?AUTO_INCREMENT=1?DEFAULT?CHARSET=utf8mb4;

測試一下正常的帶name條件查詢,效率如下:

select?*?from?tb_test?where?name?like?'1805.59281427%'

我們以name字段為例,創(chuàng)建前綴索引,找出最合適的prefix_length值。

首先,我們大致計算一下name字段全列的區(qū)分度。

可以看到,結(jié)果為 0.9945,也就是說全局不相同的數(shù)據(jù)率在99.45%這個比例。

下面我們一起來看看,不同的prefix_length值下,對應(yīng)的數(shù)據(jù)不重復(fù)比例。

當(dāng)prefix_length5,區(qū)分度為0.2237

當(dāng)prefix_length10,區(qū)分度為0.9944

當(dāng)prefix_length11,區(qū)分度為0.9945

通過對比,我們發(fā)現(xiàn)當(dāng)prefix_length11,最接近全局區(qū)分度,因此可以為name創(chuàng)建一個長度為11的前綴索引,創(chuàng)建索引語句如下:

alter?table?tb_test?add?key(name(11));

下面,我們再試試上面那個語句查詢!

創(chuàng)建前綴索引之后,查詢效率倍增

四、使用前綴索引需要注意的事項

是不是所有的字段,都適合用前綴索引呢?

答案顯然不是,在上文我們也說到了,當(dāng)某個索引的字符串列很大時,創(chuàng)建的索引也就變得很大,為了減小索引體積,提高索引的掃描速度,使用索引的前部分字符串作為索引值,這樣索引占用的空間就會大大減少,并且索引的選擇性也不會降低很多,這時前綴索引顯現(xiàn)的作用就會非常明顯,前綴索引本質(zhì)是索引查詢性能和存儲空間的一種平衡。

對于 BLOB 和 TEXT 列進(jìn)行索引,或者非常長的 VARCHAR 列,就必須使用前綴索引,因為 MySQL 不允許索引它們的全部長度。

但是如果某個字段內(nèi)容,比如前綴部分相似度很高,此時的前綴索引顯現(xiàn)效果就不會很明顯,采用覆蓋索引效果會更好!

五、小結(jié)

好了,本文主要圍繞前綴索引做了一次初步的知識講解,具體數(shù)據(jù)庫表索引的選擇性,還需要結(jié)合業(yè)務(wù)實際需求來考慮!

以上就是一文搞懂什么是MySQL前綴索引的詳細(xì)內(nèi)容,更多關(guān)于MySQL前綴索引的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • MySQL優(yōu)化中B樹索引知識點總結(jié)

    MySQL優(yōu)化中B樹索引知識點總結(jié)

    在本文里我們給大家整理了關(guān)于MySQL優(yōu)化中B樹索引的相關(guān)知識點內(nèi)容,需要的朋友們可以學(xué)習(xí)下。
    2019-02-02
  • mysql的in會不會讓索引失效?

    mysql的in會不會讓索引失效?

    今天小編就為大家分享一篇關(guān)于mysql的in會不會讓索引失效?,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-04-04
  • mysql中的json查詢過程

    mysql中的json查詢過程

    在MySQL數(shù)據(jù)庫中,進(jìn)行JSON格式數(shù)據(jù)的查詢時,需要使用特定函數(shù)和路徑表達(dá)式來實現(xiàn),本文給大家介紹mysql中的json查詢過程,感興趣的朋友一起看看吧
    2024-09-09
  • mysql主從同步原理及應(yīng)用場景示例詳解

    mysql主從同步原理及應(yīng)用場景示例詳解

    這篇文章主要為大家介紹了mysql主從同步原理及應(yīng)用場景示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-08-08
  • MySQL中的ALTER EVENT語句的具體使用

    MySQL中的ALTER EVENT語句的具體使用

    EVENT?是一種特殊的數(shù)據(jù)庫對象,它允許你在指定的時間間隔或特定的時間自動執(zhí)行SQL語句或語句集,本文主要介紹了MySQL中的ALTER EVENT語句的具體使用,感興趣的可以了解一下
    2024-07-07
  • mysql中提高Order by語句查詢效率的兩個思路分析

    mysql中提高Order by語句查詢效率的兩個思路分析

    在MySQL數(shù)據(jù)庫中,Order by語句的使用頻率是比較高的。但是眾所周知,在使用這個語句時,往往會降低數(shù)據(jù)查詢的性能。
    2011-03-03
  • Mysql中事務(wù)ACID的實現(xiàn)原理詳解

    Mysql中事務(wù)ACID的實現(xiàn)原理詳解

    這篇文章主要給大家介紹了關(guān)于Mysql中事務(wù)ACID實現(xiàn)原理的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用Mysql具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-05-05
  • MSSQL產(chǎn)生死鎖的根本原因及解決方法

    MSSQL產(chǎn)生死鎖的根本原因及解決方法

    死鎖是指兩個或兩個以上的進(jìn)程在執(zhí)行過程中,因爭奪資源而造成的一種互相等待的現(xiàn)象,若無外力作用,它們都將無法推進(jìn)下去.此時稱系統(tǒng)處于死鎖狀態(tài)或系統(tǒng)產(chǎn)生了死鎖,這些永遠(yuǎn)在互相等的進(jìn)程稱為死鎖進(jìn)程
    2016-04-04
  • 淺析mysql遷移到clickhouse的5種方法

    淺析mysql遷移到clickhouse的5種方法

    這篇文章主要介紹了mysql遷移到clickhouse的5種方法,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-07-07
  • MySQL中SHOW TABLE STATUS的使用及說明

    MySQL中SHOW TABLE STATUS的使用及說明

    這篇文章主要介紹了MySQL中SHOW TABLE STATUS的使用及說明,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-10-10

最新評論