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

一文簡(jiǎn)單了解MySQL前綴索引

 更新時(shí)間:2022年04月02日 10:21:46   作者:mashen  
MySQL是支持前綴索引的,也就是說(shuō)你可以定義字符串的一部分作為索引,下面這篇文章主要給大家介紹了關(guān)于MySQL前綴索引的相關(guān)資料,需要的朋友可以參考下

當(dāng)要索引的列字符很多時(shí) 索引則會(huì)很大且變慢

( 可以只索引列開(kāi)始的部分字符串 節(jié)約索引空間 從而提高索引效率 )

原則: 降低重復(fù)的索引值

例如現(xiàn)在有一個(gè)地區(qū)表

areagdpcode
chinaShanghai100aaa
chinaDalian200bbb
usaNewYork300ccc
chinaFuxin400ddd
chinaBeijing500eee

發(fā)現(xiàn) area 字段很多都是以 china 開(kāi)頭的

那么如果以前1-5位字符做前綴索引就會(huì)出現(xiàn)大量索引值重復(fù)的情況

索引值重復(fù)性越低 查詢(xún)效率也就越高

前綴索引測(cè)試

// 創(chuàng)建一個(gè)測(cè)試表
CREATE TABLE `x_test` (
  `id` int(11) unsigned NOT NULL AUTO_INCREMENT,
  `x_name` varchar(255) NOT NULL,
  `x_time` int(10) NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=4145025 DEFAULT CHARSET=utf8mb4

// 添加200萬(wàn)條測(cè)試數(shù)據(jù)
INSERT INTO x_test(x_name,x_time) SELECT CONCAT(rand()*3300102,x_name),x_time FROM x_test WHERE id < 30000;

200萬(wàn) 測(cè)試數(shù)據(jù)

  • 在無(wú)任何索引的情況下隨便查詢(xún)一條
    SELECT * FROM x_test WHERE x_name = '1892008.205824857823401.800099203178258.8904820949682635656.62526521254';查詢(xún)時(shí)間:2.253s

  • 添加前綴索引 ( 以第一位字符創(chuàng)建前綴索引 )
    alter table x_test add index(x_name(1))再次查詢(xún)相同sql語(yǔ)句
    SELECT * FROM x_test WHERE x_name = '1892008.205824857823401.800099203178258.8904820949682635656.62526521254';查詢(xún)時(shí)間:3.291s
    當(dāng)使用第一位字符創(chuàng)建前綴索引后 貌似查詢(xún)的時(shí)間更長(zhǎng)了
    因?yàn)橹坏谝晃蛔址运饕档闹刈x性太大了
    200萬(wàn)條數(shù)據(jù)全以數(shù)字開(kāi)頭那么平均20萬(wàn)條的數(shù)據(jù)都是相同的索引值

  • 重新建立前綴索引 這次以前4位字符來(lái)創(chuàng)建
    alter table x_test add index(x_name(4));再次查詢(xún)相同sql語(yǔ)句
    SELECT * FROM x_test WHERE x_name = '1892008.205824857823401.800099203178258.8904820949682635656.62526521254';查詢(xún)時(shí)間:0.703s
    這次以前4位創(chuàng)建索引 大大減少了索引值的重復(fù)性 查詢(xún)速度從3秒提升到0.7秒

  • 200萬(wàn)條數(shù)據(jù)都以數(shù)字開(kāi)頭 而0-9排列組合7位則可達(dá)到千萬(wàn)種組合
    也就是以前7位來(lái)做索引則不會(huì)出現(xiàn)重復(fù)索引值的情況了
    alter table x_test add index(x_name(7));再次查詢(xún)相同sql語(yǔ)句
    SELECT * FROM x_test WHERE x_name = '1892008.205824857823401.800099203178258.8904820949682635656.62526521254';查詢(xún)時(shí)間:0.014s ( 首次執(zhí)行無(wú)緩存狀態(tài)下 )

補(bǔ)充:使用前綴索引的執(zhí)行過(guò)程

  1. 從index2的索引樹(shù)上,找到滿(mǎn)足索引值是“zhangs”的記錄,找到第一個(gè)是ID1;
  2. 到主鍵索引樹(shù)上查到ID1這一行,判斷email的值滿(mǎn)不滿(mǎn)足where后的條件,不滿(mǎn)足這一行丟棄。
  3. 繼續(xù)回到index2這個(gè)索引樹(shù)上查下一條記錄,發(fā)現(xiàn)如果還是"zhangs",取出ID2,再回到ID2索引樹(shù)上進(jìn)行判斷,如果值正確,將結(jié)果返回結(jié)果集中。
  4. 重復(fù)執(zhí)行以上流程,直到從index2索引樹(shù)上取出的數(shù)據(jù)不是“zhangs”,循環(huán)結(jié)束。

通過(guò)以上執(zhí)行流程的分析你就可以知道,前綴索引會(huì)導(dǎo)致掃描的行數(shù)變多,這和你所指定前綴的長(zhǎng)度有關(guān)?;蛟Semail(7)中的區(qū)分度就比email(6)高,就不會(huì)掃描那么多行。

也即是說(shuō)使用前綴索引,定義好長(zhǎng)度,就可以節(jié)省空間又不用額外增加太多的查詢(xún)成本

那怎樣定義前綴索引長(zhǎng)度比較好呢?

實(shí)際上,建立索引時(shí)關(guān)注的是區(qū)分度,區(qū)分度越高,越能體現(xiàn)索引的價(jià)值和他的優(yōu)勢(shì)。因此我們可以通過(guò)統(tǒng)計(jì)索引上有不同的值來(lái)判斷要使用多長(zhǎng)的前綴。

select count(distinct email) as L from User;

MySQL 5.7 參考手冊(cè) - 前綴索引

總結(jié)

到此這篇關(guān)于MySQL前綴索引的文章就介紹到這了,更多相關(guān)MySQL前綴索引內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • MySQL中空值Null和空字符‘‘的具體使用

    MySQL中空值Null和空字符‘‘的具體使用

    本文主要介紹了MySQL中空值Null和空字符''的具體使用,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • mysql5.7安裝及配置教程

    mysql5.7安裝及配置教程

    這篇文章主要為大家詳細(xì)介紹了mysql5.7安裝及配置教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-11-11
  • 利用rpm安裝mysql 5.6版本詳解

    利用rpm安裝mysql 5.6版本詳解

    眾所周知MySQL在很多領(lǐng)域都被廣泛的使用,尤其是很多互聯(lián)網(wǎng)企業(yè),諸如騰訊,阿里等等。那么本文將主要介紹如何通過(guò)rpm方式來(lái)安裝Mysql,這是比較簡(jiǎn)單的一種安裝方式,文中介紹的很詳細(xì),相信對(duì)于大家安裝mysql具有一定的參考借鑒價(jià)值,下面來(lái)一起看看吧。
    2016-11-11
  • MySql5.7.21安裝要點(diǎn)記錄筆記

    MySql5.7.21安裝要點(diǎn)記錄筆記

    這篇文章主要介紹了mysql5.7.21安裝要點(diǎn)記錄筆記,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2018-02-02
  • mysql查看鎖表及殺進(jìn)程問(wèn)題

    mysql查看鎖表及殺進(jìn)程問(wèn)題

    這篇文章主要介紹了mysql查看鎖表及殺進(jìn)程問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • 一文帶你分清MySQL回表查詢(xún)與索引覆蓋

    一文帶你分清MySQL回表查詢(xún)與索引覆蓋

    這篇文章主要給大家詳細(xì)介紹如何分清MySQL回表查詢(xún)與索引覆蓋,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-07-07
  • MySQL 文本文件的導(dǎo)入導(dǎo)出數(shù)據(jù)的方法

    MySQL 文本文件的導(dǎo)入導(dǎo)出數(shù)據(jù)的方法

    但有時(shí)為了更快速地插入大批量數(shù)據(jù)或交換數(shù)據(jù),需要從文本中導(dǎo)入數(shù)據(jù)或?qū)С鰯?shù)據(jù)到文本。下面的具體的方法大家可以參考下。多測(cè)試。
    2009-11-11
  • 淺談MySQL排序原理與案例分析

    淺談MySQL排序原理與案例分析

    這篇文章主要介紹了淺談MySQL排序原理與案例分析的相關(guān)資料,需要的朋友可以參考下
    2016-03-03
  • Mysql中xtrabackup備份的實(shí)現(xiàn)

    Mysql中xtrabackup備份的實(shí)現(xiàn)

    Xtrabackup是Percona團(tuán)隊(duì)開(kāi)發(fā)的用于MySQL數(shù)據(jù)庫(kù)物理熱備份的開(kāi)源備份工具,本文就來(lái)介紹一下Mysql中xtrabackup備份的實(shí)現(xiàn),就有一定的參考價(jià)值,感興趣的可以了解一下
    2023-12-12
  • MySQL調(diào)優(yōu)之SQL查詢(xún)深度分頁(yè)問(wèn)題

    MySQL調(diào)優(yōu)之SQL查詢(xún)深度分頁(yè)問(wèn)題

    本文主要介紹了MySQL調(diào)優(yōu)之SQL查詢(xún)深度分頁(yè)問(wèn)題,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-03-03

最新評(píng)論