码迷,mamicode.com
首页 > 数据库 > 详细

Mysql 为什么要选择 B+Tree

时间:2019-10-23 18:22:53      阅读:130      评论:0      收藏:0      [点我收藏+]

标签:连接   红黑树   大小   btree   一个个   范围   image   src   png   

技术图片算法对比

二叉树

技术图片
当我查找 8 的时候需要走五步

技术图片
红黑树

技术图片
当我查询8的时候需要四次 相对于二叉树有了一些优化 没有无限延伸.红黑树的深度会很深(深度不可控制)

技术图片
hash

数据量大的话

技术图片
查询很快(不能范围查找)

BTree

技术图片
查询只需要查两步就可以找到,缺点携带(data)扩大横向减少纵向深度

ps:java拿取数据一般是这样的:java程序-->CPU--->内存---->硬盘,而内存与硬盘的交互是有大小限制的,是一页数据4k左右,所以不能把所有数据都放在一个节点来获取,一般来说节点会尽量预存4K容量。
技术图片
B+Tree

Mysql 为什么要选择 B+Tree
技术图片

ps:data不放在非叶子节点来增加度(小节点),一般会一百个以上使得深度是3~5,从而减少查询次数。并且,叶子节点之间会有指针,数据又是递增的,这使得我们范围查找可以通过指针连接查找,而不再从上面节点往下一个个找。既减少了查询次数,又提供了范围查询.

Mysql 为什么要选择 B+Tree

标签:连接   红黑树   大小   btree   一个个   范围   image   src   png   

原文地址:https://blog.51cto.com/14207399/2444814

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!