亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

MySQL給字符串加一個高效索引的實現(xiàn)

 更新時間:2023年03月20日 10:06:34   作者:程序員拾山  
本文主要介紹了MySQL給字符串加一個高效索引的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

需求

在日常需求中,用戶使用手機號或者郵箱登錄某一個系統(tǒng),是一個很常見的操作,那如何在類似手機號或者郵箱這樣的字段上建立一個合理的索引呢?

前綴索引

前綴索引,就是以一個字段值的一部分作為索引。我們在MySQL中創(chuàng)建索引時,如果不指定索引字段的長度,那么就會以整個字符串來建立索引。

語句1:
alter table test add index idx(email);
語句2:
alter table test add index idx(email(8));

對于語句1,創(chuàng)建的索引中,會包含每條記錄中的整個email字符串值。

對于語句2,創(chuàng)建的索引中,保存的是每條記錄中email字段的前8個字節(jié)。

使用前綴索引的優(yōu)勢很明顯,那就是索引占用的空間會更小,整個索引樹會更緊湊,樹的高度相對更低。

但是相應的,索引的區(qū)分度會變低,可能導致索引掃描行數(shù)增加。

在我們創(chuàng)建索引時,索引的區(qū)分度是一個很重要的指標。區(qū)分度越高,重復的值就越少,掃描的效率就越高。

在使用前綴索引時,合理規(guī)劃使用的前綴長度,不僅可以節(jié)省空間,還可以不用額外增加掃描的行數(shù)。具體使用多少的長度,建議根據(jù)我們的實際業(yè)務場景來判斷、測試。

倒序+前綴索引

倒序+前綴索引有一個經(jīng)典的使用場景,就是對身份證號做索引。

假設我們現(xiàn)在要維護一個市縣所有人的身份信息,其中按身份證號查詢是一個高頻場景。

身份證號碼一共15位或者18位,一般來說,同一個市縣的人身份證號前6位一般是相同的,如果直接對身份證號做全索引,那么會比較浪費空間,導致性能下降。直接前綴索引的話,前6位的區(qū)分度又很低(甚至可以說沒有,因為大家前6位基本都一樣)。

這時,使用倒序+前綴索引的好處就體現(xiàn)出來了。

我們先將身份證倒序存儲,或者冗余一個倒序的身份證號字段,然后取前6位做前綴索引。

身份證后6位的區(qū)分度已經(jīng)基本上夠我們使用了,如果你還覺得查詢速度不夠,那取前8位也是沒問題的。

總結

我們之所以盡量避免對字符串加全值索引,是因為字符串字段的長度不好預估,可能會變得很大。在一個值很大的字段上做索引,會額外的占用更多的空間,數(shù)據(jù)頁上可存儲的索引值會變少,導致MySQL樹的高度變高,這樣查詢數(shù)據(jù)時,IO增加,性能下降。

但是,凡事都有例外,有時我們也不能為了優(yōu)化而優(yōu)化。

比如我們現(xiàn)在要維護一個高校的師生信息,按整個學校2萬人,每年新增1萬新學生來計算,10年時間也不過12萬數(shù)據(jù)而已。即使在一個身份證號字段上加上全字段索引又能多占用多少空間呢?能省出多少性能呢?

有時,從業(yè)務量預估優(yōu)化和收益比,也是一個很好的習慣。

到此這篇關于MySQL給字符串加一個高效索引的實現(xiàn)的文章就介紹到這了,更多相關MySQL字符串高效索引內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • MySQL中Set與Enum的區(qū)別和使用詳解

    MySQL中Set與Enum的區(qū)別和使用詳解

    這篇文章主要介紹了MySQL中Set與Enum的區(qū)別和使用詳解,數(shù)據(jù)庫中的 set 是一種集合數(shù)據(jù)類型,用于存儲不同的元素,每個元素只能出現(xiàn)一次,Set 的主要作用是方便進行集合運算,如并集、交集等操作,需要的朋友可以參考下
    2024-01-01
  • MYSQL使用inner join 進行 查詢/刪除/修改示例

    MYSQL使用inner join 進行 查詢/刪除/修改示例

    本文為大家介紹下使用inner join 進行查詢/刪除/修改,具體實現(xiàn)如下,學習mysql的朋也可以學習下,希望對大家有所幫助
    2013-07-07
  • mssql2008 自定義表類型實現(xiàn)(批量插入或者修改)

    mssql2008 自定義表類型實現(xiàn)(批量插入或者修改)

    在做大型網(wǎng)站或者系統(tǒng)的時候,經(jīng)常會遇到個問題就是批量插入或者修改數(shù)據(jù)庫;今天這邊不講SqlBulkCopy,只簡單講sql自定義表類型,感興趣的朋友可以了解下哦,希望本文對你有所幫助
    2013-01-01
  • mysql 8.0.18 安裝配置圖文教程

    mysql 8.0.18 安裝配置圖文教程

    這篇文章主要為大家詳細介紹了mysql 8.0.18 安裝配置圖文教程,文中安裝步驟介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-11-11
  • 面試官問訂單ID是如何生成的?難道不是MySQL自增主鍵

    面試官問訂單ID是如何生成的?難道不是MySQL自增主鍵

    最近在考慮訂單id怎么生成,下面這篇文章主要給大家介紹了關于面試官問訂單ID是如何生成的?難道不是MySQL自增主鍵的相關資料,需要的朋友可以參考下
    2023-02-02
  • mysql的group_concat函數(shù)使用示例

    mysql的group_concat函數(shù)使用示例

    這篇文章主要介紹了mysql的group_concat函數(shù)使用示例,需要的朋友可以參考下
    2014-04-04
  • Linux下徹底卸載mysql詳解

    Linux下徹底卸載mysql詳解

    如何在Linux下徹底的卸載MySQL數(shù)據(jù)庫呢? 下面這篇文章就給大家總結、整理了一下在Linux平臺下徹底卸載MySQL的方法。 文中通過圖文及示例代碼介紹的很詳細,相信對大家的理解和學習很有幫助,下面有需要的朋友們來一起學習學習吧。
    2016-11-11
  • MySQL初學者可以告別分組聚合查詢的困擾了

    MySQL初學者可以告別分組聚合查詢的困擾了

    這篇文章主要為大家介紹了MySQL分組聚合查詢的難點講解,幫助MySQL初學著告別分組聚合查詢的困擾,有需要的朋友可以借鑒參考下,希望能夠有所進步
    2021-10-10
  • ubuntu下apt-get安裝和徹底卸載mysql詳解

    ubuntu下apt-get安裝和徹底卸載mysql詳解

    本文給大家分享ubuntu下apt-get安裝和徹底卸載mysql的方法,文中提到了安裝mysq命令查看mysql是否運行的命令寫法,具體內(nèi)容詳情大家通過本文學習吧
    2017-08-08
  • MySQL底層數(shù)據(jù)結構選用B+樹的原因

    MySQL底層數(shù)據(jù)結構選用B+樹的原因

    大家好,本篇文章主要講的是MySQL底層數(shù)據(jù)結構選用B+樹的原因,感興趣的同學趕快來看一看吧,對你有幫助的話記得收藏一下,方便下次瀏覽
    2021-12-12

最新評論