一步步分析为什么B+树适合作为索引的结构
面试官问你B树和B+树,就把这篇文章丢给他
浅谈算法和数据结构: 十 平衡查找树之B树
为何文件索引要用B树而不用二叉查找树?
单纯地看比较次数的话,二叉查找树和B树差不多,甚至可能二叉查找树比较次数更少。
在把磁盘里的数据加载到内存中的时候,是以页为单位来加载的,而我们也知道,节点与节点之间的数据是不连续的,所以不同的节点,很有可能分布在不同的磁盘页中。所以还要考虑到磁盘的寻址加载次数。
而因为B树的一个节点是可以存储多个元素的,所以其磁盘寻址加载次数通常会更少。
mysql用B+树不用B树的主要原因
数据库索引采用B+树的主要原因是B树在提高了磁盘IO性能的同时并没有解决元素遍历的效率低下的问题。正是为了解决这个问题,B+树应运而生。B+树只要遍历叶子节点就可以实现整棵树的遍历。而且在数据库中基于范围的查询是非常频繁的,而B树不支持这样的操作(或者说效率太低)。