B树和B+树是解决什么样的问题的,怎样演化过来,之间区别

开课吧开课吧锤锤2021-02-08 14:45

B树和B+树,这题既问mysql索引的实现原理,也问数据结构基础

首先从二叉树说起,因为会产生退化现象,提出了平衡二叉树,再提出怎样让每一层放的节点多一些来减少遍历高度,引申出m叉树,m叉搜索树同样会有退化现象,引出m叉平衡树,也就是B树,这时候每个节点既放了key也放了value,怎样使每个节点放尽可能多的key值,以减少遍历高度呢(访问磁盘次数),可以将每个节点只放key值,将value值放在叶子结点,在叶子结点的value值增加指向相邻节点指针,这就是优化后的B+树。

开课吧广场Java面试

然后谈谈数据库索引失效的情况,为什么给离散度低的字段(如性别)建立索引是不可取的,查询数据反而更慢,如果将离散度高的字段和性别建立联合索引会怎样,有什么需要注意的?

以上就是小编今天为大家整理发布的Java面试题,希望为正在学习Java语言的的朋友提供有用的面试素材,更多Java面试题尽在开课吧广场Java面试频道!

有用
分享
全部评论快来秀出你的观点
登录 后可发表观点…
发表
暂无评论,快来抢沙发!
高并发编程训练营