Mysql 為什么要選擇 B+Tree


算法對比

二叉樹

file

當我查找 8 的時候需要走五步

file

紅黑樹

file

當我查詢8的時候需要四次 相對於二叉樹有了一些優化 沒有無限延伸.紅黑樹的深度會很深(深度不可控制)

file

hash

數據量大的話

file

查詢很快(不能范圍查找)

BTree

file

查詢只需要查兩步就可以找到,缺點攜帶(data)擴大橫向減少縱向深度
ps:java拿取數據一般是這樣的:java程序-->CPU--->內存---->硬盤,而內存與硬盤的交互是有大小限制的,是一頁數據4k左右,所以不能把所有數據都放在一個節點來獲取,一般來說節點會盡量預存4K容量。

file

B+Tree

file

BTree 變種B+Tree
ps:data不放在非葉子節點來增加度(小節點),一般會一百個以上使得深度是3~5,從而減少查詢次數。並且,葉子節點之間會有指針,數據又是遞增的,這使得我們范圍查找可以通過指針連接查找,而不再從上面節點往下一個個找。既減少了查詢次數,又提供了范圍查詢.
所以mysql采用的B+Tree算法

blockchain


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM