日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

MySQL btree索引與hash索引區別

瀏覽:193日期:2023-10-11 08:51:22

在MySQL中,大多數索引(如 PRIMARY KEY,UNIQUE,INDEX和FULLTEXT)都是在BTREE中存儲,但使用memory引擎可以選擇BTREE索引或者HASH索引,兩種不同類型的索引各自有其不同的使用范圍。

B樹索引具有范圍查找和前綴查找的能力,對于有N節點的B樹,檢索一條記錄的復雜度為O(LogN)。相當于二分查找。 哈希索引只能做等于查找,但是無論多大的Hash表,查找復雜度都是O(1)。

顯然,如果值的差異性大,并且以等值查找(=、 <、>、in)為主,Hash索引是更高效的選擇,它有O(1)的查找復雜度。如果值的差異性相對較差,并且以范圍查找為主,B樹是更好的選擇,它支持范圍查找。

一、HASH索引

利用哈希函數,計算存儲地址,檢索時不需要像Btree那樣,從根節點開始遍歷,逐級查找。

Hash 索引結構的特殊性,其檢索效率非常高,索引的檢索可以一次定位,不像B-Tree 索引需要從根節點到枝節點,最后才能訪問到頁節點這樣多次的IO訪問,所以 Hash 索引的查詢效率要遠高于 B-Tree 索引。

可能很多人又有疑問了,既然 Hash 索引的效率要比 B-Tree 高很多,為什么大家不都用 Hash 索引而還要使用 B-Tree 索引呢?任何事物都是有兩面性的,Hash 索引也一樣,雖然 Hash 索引效率高,但是 Hash 索引本身由于其特殊性也帶來了很多限制和弊端,主要有以下這些。

(1)Hash 索引僅僅能滿足”=”,”IN”和”<=>”查詢,不能使用范圍查詢(查詢范圍時 慢)。

由于 Hash 索引比較的是進行 Hash 運算之后的 Hash 值,所以它只能用于等值的過濾,不能用于基于范圍的過濾,因為經過相應的 Hash 算法處理之后的 Hash 值的大小關系,并不能保證和Hash運算前完全一樣。

(2)Hash 索引無法被用來避免數據的排序操作。

由于 Hash 索引中存放的是經過 Hash 計算之后的 Hash 值,而且Hash值的大小關系并不一定和 Hash 運算前的鍵值完全一樣,所以數據庫無法利用索引的數據來避免任何排序運算;

(3)Hash 索引不能利用部分索引鍵查詢。

對于組合索引,Hash 索引在計算 Hash 值的時候是組合索引鍵合并后再一起計算 Hash 值,而不是單獨計算 Hash 值,所以通過組合索引的前面一個或幾個索引鍵進行查詢的時候,Hash 索引也無法被利用。

(4)Hash 索引在任何時候都不能避免表掃描。

前面已經知道,Hash 索引是將索引鍵通過 Hash 運算之后,將 Hash運算結果的 Hash 值和所對應的行指針信息存放于一個 Hash 表中,由于不同索引鍵存在相同 Hash 值,所以即使取滿足某個 Hash 鍵值的數據的記錄條數,也無法從 Hash 索引中直接完成查詢,還是要通過訪問表中的實際數據進行相應的比較,并得到相應的結果。

(5)Hash 索引遇到大量Hash值相等的情況后性能并不一定就會比B-Tree索引高。

對于選擇性比較低的索引鍵,如果創建 Hash 索引,那么將會存在大量記錄指針信息存于同一個 Hash 值相關聯。這樣要定位某一條記錄時就會非常麻煩,會浪費多次表數據的訪問,而造成整體性能低下。

二、B+樹

MySQL btree索引與hash索引區別

b+樹的查找過程

如圖所示,如果要查找數據項29,那么首先會把磁盤塊1由磁盤加載到內存,此時發生一次IO,在內存中用二分查找確定29在17和35之間,鎖定磁盤塊1的P2指針,內存時間因為非常短(相比磁盤的IO)可以忽略不計,通過磁盤塊1的P2指針的磁盤地址把磁盤塊3由磁盤加載到內存,發生第二次IO,29在26和30之間,鎖定磁盤塊3的P2指針,通過指針加載磁盤塊8到內存,發生第三次IO,同時內存中做二分查找找到29,結束查詢,總計三次IO。真實的情況是,3層的b+樹可以表示上百萬的數據,如果上百萬的數據查找只需要三次IO,性能提高將是巨大的,如果沒有索引,每個數據項都要發生一次IO,那么總共需要百萬次的IO,顯然成本非常非常高。

b+樹性質

1.索引字段要盡量的小:

通過上面的分析,我們知道IO次數取決于b+數的高度h,假設當前數據表的數據為N,每個磁盤塊的數據項的數量是m,則有h=?(m+1)N,當數據量N一定的情況下,m越大,h越小;而m = 磁盤塊的大小 / 數據項的大小,磁盤塊的大小也就是一個數據頁的大小,是固定的,如果數據項占的空間越小,數據項的數量越多,樹的高度越低。這就是為什么每個數據項,即索引字段要盡量的小,比如int占4字節,要比bigint8字節少一半。這也是為什么b+樹要求把真實的數據放到葉子節點而不是內層節點,一旦放到內層節點,磁盤塊的數據項會大幅度下降,導致樹增高。當數據項等于1時將會退化成線性表。

2.索引的最左匹配特性(即從左往右匹配):

當b+樹的數據項是復合的數據結構,比如(name,age,sex)的時候,b+數是按照從左到右的順序來建立搜索樹的,比如當(張三,20,F)這樣的數據來檢索的時候,b+樹會優先比較name來確定下一步的所搜方向,如果name相同再依次比較age和sex,最后得到檢索的數據;但當(20,F)這樣的沒有name的數據來的時候,b+樹就不知道下一步該查哪個節點,因為建立搜索樹的時候name就是第一個比較因子,必須要先根據name來搜索才能知道下一步去哪里查詢。比如當(張三,F)這樣的數據來檢索時,b+樹可以用name來指定搜索方向,但下一個字段age的缺失,所以只能把名字等于張三的數據都找到,然后再匹配性別是F的數據了, 這個是非常重要的性質,即索引的最左匹配特性。

以上就是MySQL btree索引與hash索引區別的詳細內容,更多關于MySQL btree索引與hash索引的資料請關注好吧啦網其它相關文章!

標簽: MySQL 數據庫
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产精品男女| 中国女人久久久| 免费人成网站在线观看欧美高清| 四虎884aa成人精品最新| 国产一区二区三区久久| 亚洲小说春色综合另类电影| 亚洲一区二区日韩| 亚洲资源网站| 日韩国产在线不卡视频| 日韩和欧美一区二区三区| 日韩精选在线| 国产黄色精品| 成人羞羞视频播放网站| 午夜日本精品| 欧美三级第一页| 激情欧美一区| 日韩国产欧美三级| 国产视频一区免费看| 日韩影院精彩在线| 日本在线观看不卡视频| 亚洲一区二区三区久久久| 日韩高清一区| 美女高潮久久久| jizzjizz中国精品麻豆| 日韩视频在线一区二区三区| 免费的成人av| 精品一区二区三区免费看| 欧美日韩尤物久久| 亚洲18在线| 国产999精品在线观看| 国产一区清纯| 国产伦精品一区二区三区在线播放 | 91嫩草精品| 99久久视频| 日韩在线观看一区二区三区| 日韩电影二区| 国产精久久一区二区| 亚洲精品一区二区妖精| 黄色av日韩| 日韩一级欧洲| 久久国产精品美女| 国产高清视频一区二区| 久久精品xxxxx| 国产v日韩v欧美v| 中文在线免费视频| 亚洲一本视频| 亚洲一级大片| 精品一区二区三区四区五区| 蜜桃av在线播放| 六月婷婷一区| zzzwww在线看片免费| 麻豆久久一区| 欧美专区一区| 亚洲午夜在线| 91精品蜜臀一区二区三区在线 | 亚洲最大av| 欧美aa一级| 国产91在线播放精品| 国产精品免费不| 国产欧美日韩免费观看| 欧美亚洲三区| 国产乱码精品一区二区三区亚洲人| 国产毛片久久| 免费日韩av片| 亚洲欧洲av| 久久最新视频| 日韩精品高清不卡| 日韩在线观看中文字幕| 欧美在线观看天堂一区二区三区| 日韩精品国产欧美| 国产精品啊v在线| 免费日韩一区二区三区| 国产精品伦一区二区| 欧美黄页在线免费观看| 高清av一区| 亚洲精品在线观看91| 亚洲精品美女91| 久草精品视频| 国产欧美高清| 人人香蕉久久| 国产欧美午夜| 伊伊综合在线| 国产精品久久久网站| 国产亚洲一区二区三区不卡| 欧美日韩在线观看首页| 日韩福利视频一区| 国产美女高潮在线观看| 亚洲欧美高清| 国产a久久精品一区二区三区| 亚洲一区二区动漫| 中文一区一区三区高中清不卡免费| 亚洲精一区二区三区| 久久天堂精品| 精品视频一区二区三区四区五区| 亚洲一区二区三区久久久| 激情综合激情| 成人日韩在线观看| 精品国产美女a久久9999| 日韩精品a在线观看91| 视频在线观看一区| 午夜精品婷婷| 国产亚洲一区| 蜜臀久久99精品久久久久久9 | 精品一区二区三区四区五区| 日本精品一区二区三区在线观看视频| 成人久久久久| 久久精选视频| 日本不卡免费高清视频在线| 精品一区二区三区在线观看视频| 欧美日韩一区二区高清| 日韩中文欧美在线| 蜜臀av亚洲一区中文字幕| 久久国产中文字幕| 四虎884aa成人精品最新| 99久久99久久精品国产片果冰| 国产精品亚洲产品| 国产精品成人自拍| 国产中文欧美日韩在线| 中文字幕成在线观看| 欧美午夜精彩| 蜜臀精品一区二区三区在线观看 | 久久麻豆精品| 久久超级碰碰| 天堂成人免费av电影一区| 日韩视频精品在线观看| 日韩va欧美va亚洲va久久| 91亚洲国产高清| 红桃视频欧美| 亚洲影院天堂中文av色| 久久av超碰| 蜜臀精品一区二区三区在线观看| 日韩久久一区| 在线天堂资源www在线污| 视频一区二区中文字幕| 国产美女亚洲精品7777| 一区二区三区四区在线看| 日韩欧美2区| 激情久久久久久久| 国产精品videossex| 欧美日韩在线网站| 国产精品视频首页| 影音先锋久久| 日本aⅴ精品一区二区三区| 日韩精品一区二区三区免费观看| 日韩有码av| 久久中文字幕av| 久久精品毛片| 日韩欧美中文字幕一区二区三区 | 欧美日韩一区二区三区四区在线观看 | 亚洲免费一区三区| 911亚洲精品| 色综合狠狠操| 欧美中文日韩| 国产999精品在线观看| 自由日本语亚洲人高潮| 国产精品videossex久久发布| 久久激情婷婷| 国产精品蜜月aⅴ在线| 欧洲亚洲一区二区三区| 日本在线一区二区三区| 亚洲日本网址| 国产一级成人av| 婷婷国产精品| 91日韩在线| 国产毛片精品| 亚洲一级大片| 深夜视频一区二区| 国产欧美日韩精品高清二区综合区| 久久一区二区三区电影| 国产精品男女| 日韩精品中文字幕一区二区| 亚洲先锋成人| 久久天堂av| 福利视频一区| 欧美天堂在线| 亚洲影视一区二区三区| 国产一区日韩一区| 国产中文欧美日韩在线| 日本欧美韩国一区三区| 日韩精品一区第一页| 欧美日韩高清| 亚洲网站视频| 激情五月综合网| 五月综合激情| 亚洲午夜91| 亚洲免费成人| 亚洲免费黄色| 影院欧美亚洲| 免费成人在线影院| 亚洲精品日本| 免费一区二区视频| 日韩精品一二三区| 麻豆久久精品| 亚洲日本在线观看视频| 日韩超碰人人爽人人做人人添| 亚洲精品在线a| 欧美永久精品| 国产成人精品一区二区三区在线| 麻豆国产一区| 一本大道色婷婷在线|