一 概述
我们在使用数据库的时候,经常会使用到索引,此时的就会设计到索引的数据结构,其实我们都听说过B+Tree这个数据结构。
二 B+Tree和B-Tree
在索引的B-Tree结构中,每个节点都会带有指向具体记录的指针,同时不同的叶子节点之间没有连在一起,对于B-Tree的检索来说,可能在非叶子节点就能获取到指向具体记录的指针,搜索效率不稳定。
在索引的B+Tree结构中,只有叶子节点会带有指向具体记录的指针,且所有的叶子节点都通过指针连接在一起,这样获取数据的时候只能从叶子节点才可以获取具体记录的指针,搜索效率稳定。
因为B+Tree的非叶子节点不带有指向具体记录的指针,所以非叶子节点中可以存储更多的索引项,这样可以降低索引树的高度,进而提升搜索的效率。同时因为B+Tree的叶子节点都通过指针连接在一起,这样就可以很方便的实现范围扫描的需求。
对比之下,B-Tree在进行范围扫描的时候就需要不停的在叶子节点和非叶子节点之间移动。