Mysql-索引-BTree类型【精简】

原创 2016年12月08日 23:37:06
网络上看了很多关于B-TREE的总结,b树,B-树,B+树,B*树(艾玛怎么还4个呢?都快蒙圈了呢),
有的真的很精彩令人佩服,但是都是篇幅太长啊,一大长段的文字就让人望而生畏啊。干脆做一个简化版的总结,通俗移动点介绍下,说说他们的区别。
一.B树
Binary Tree,就是一个二叉树。(什么K呀h,n啥的公式这里不说了,有兴趣的可以自己搜搜..)
(1)所有非叶子结点至多拥有两个儿子(Left和Right);
(2)所有结点存储一个关键字
(3)非叶子结点的左指针指向小于其关键字的子树,右指针指向大于其关键字的子树;(简单说,左边比自己小,右边比自己大
B树

二.B-树
平衡二叉树(Balance Binary Tree) --AVL树【这里的B,其实是balance的意思哦~】
(1)根节点的左子树和右子树的深度最多相差1.(确保了不会出现上图右边的极端现象)
(2)根节点的左子树和右子树叶都是一棵平衡二叉树
(3)所有结点都有存储关键字
无论插入的序列是怎么样,我们都能通过调整构建一棵平衡二叉树,保证二叉树中的每个节点的平衡因子都不会大于1,保证了树的深度达到最浅,从而比较的次数就会更少,时间复杂度就会降低
图 B-树

三.B+树
B+的搜索与B-树也基本相同,区别是B+树只有达到叶子结点才命中(B-树可以在非叶子结点命中)
(1)所有关键字都出现在叶子结点的链表中(稠密索引),且链表中的关键字恰好是有序的;(只有根节点存储关键字最后树的末梢才有值)
(2)非叶子结点相当于是叶子结点的索引(稀疏索引),叶子结点相当于是存储(关键字)数据的数据层。(非根节点,存储的其实是指向根节点的索引
(3) 因为前两点,所以不可能在非叶子结点存数据。(区别B-的第三条)
(4)根节点横向也有链指针(方便快速顺藤摸瓜嘛,没这个指针,就算下一个取的值是挨着的邻居,也得跑个圈才能拿到)

注意,我们一般用到的索引结果,或者通常指的B-TREE结构,大部分就是在说B+结构啦~~
图 B+树
一篇还不错的文章,介绍了B+树插入的过程:http://hedengcheng.com/?p=525

四.B*树
B+树的变体,
(1)B+树的非根和非叶子结点再增加指向兄弟的指针;[对比上边B+的第4条,在非根节点也添加横向链表]
图 B * 树

五.总结:

B树:二叉树,
每个结点只存储一个关键字,等于则命中,小于走左结点,大于走右结点;(但B树在经过多次插入与删除后,有可能导致不同的结构),为此,加上平衡算法后生成平衡二叉树,又称B-树

B-树:在B 树的基础上,加上平衡算法,多路搜索树,
1.每个结点存储M/2到M个关键字,
2.非叶子结点存储指向关键字范围的子结点;
3.所有关键字在整颗树中出现,且只出现一次,

4.叶子节点,非叶子结点都可以命中(是否存了数据);


B+树:在B-树基础上,

1.为叶子结点增加链表指针

2.所有关键字都在叶子结点中出现,

3.非叶子结点作为叶子结点的索引;

4.B+树总是到叶子结点才命中;


B*树:在B+树基础上,为非叶子结点也增加链表指针,将结点的最低利用率从1/2提高到2/3;

 疑问:B*效率高了,但但觉为什么b*树用的比较少呢?????或者哪里有用吗??可能还是见的太少了。。有了解的童鞋可以互相学习下,敬请赐教,在这里先谢谢啦~
解答:最近得知,有个叫Reiser4的文件系统好像使用到了这种结构。其作者Hans Reiser,因为他老婆让他带了绿帽子,就把老婆杀了,蹲大牢了,直接影响到了项目进度。。。

介绍:
Linux文件系统ReiserFS作者Hans Reiser因谋杀妻子被判入狱15年之后,ReiserFS的开发并没有停止,虽然它至今没有合并到Linux主支。一小群开发者仍然在继续开发ReiserFS的第四个版本(简称Reiser4),他们上个月发布了新版本,支持Linux 3.5.4内核。https://en.wikipedia.org/wiki/Reiser4




版权声明:本文为博主原创文章,转载请说明出处。

MySQL BTree【index type】 原理

  • u010689306
  • u010689306
  • 2016年06月11日 17:22
  • 597

Mysql的BTree索引的原则和限制

这是自己在阅读《高性能MySQL》所做的笔记,和大家分享下 当人们谈论索引时,没有特别指明类型,那么多半就是B-Tree索引,它使用树形结构来存储数据,大多数MySQL引擎都支持这种索引类型,比如...
  • xiao2shiqi
  • xiao2shiqi
  • 2017年01月06日 18:06
  • 668

高性能Mysql:B-TREE和B+-TREE

高性能Mysql:B-TREE和B+-TREE一、索引简介数据库中,索引对于查询来说至关重要。它就像书籍里的目录一样,能在磁盘页面中迅速找到所需要的记录,能够将查询性能提高好几个数量级。所以索引是应对...
  • mr253727942
  • mr253727942
  • 2016年03月06日 14:31
  • 1794

MySQL优化之BTree索引使用规则

MySQL优化之BTree索引使用规则 从一道题开始分析: 假设某个表有一个联合索引(c1,c2,c3,c4)一下——只能使用该联合索引的c1,c2,c3部分 A where c1=x and c...
  • lipc_
  • lipc_
  • 2016年10月18日 23:36
  • 831

(Mysql 四)普通索引(BTREE索引)的使用

在mysql中,普通索引,也就是BTREE索引分两类,一个是单列索引 另一个是 多列索引 1.索引的作用: 当一个数据表只有很少量的数据时,索引体现不了他的价值。但若是一个表有10w多的数据时,查...
  • u014453898
  • u014453898
  • 2017年02月13日 02:54
  • 400

B+/-Tree原理及mysql的索引分析

B+/-Tree原理 B-Tree介绍 B-Tree是一种多路搜索树(并不是二叉的):        1.定义任意非叶子结点最多只有M个儿子;且M>2;        2.根结点的儿子数为[2...
  • tonyXf121
  • tonyXf121
  • 2012年12月23日 17:09
  • 35028

MySQL的btree索引和hash索引的区别

Hash 索引结构的特殊性,其检索效率非常高,索引的检索可以一次定位,不像B-Tree 索引需要从根节点到枝节点,最后才能访问到页节点这样多次的IO访问,所以 Hash 索引的查询效率要远高于 B...
  • kingmax54212008
  • kingmax54212008
  • 2015年11月12日 12:58
  • 5078

BTree和B+Tree详解

B 树是为了磁盘或其它存储设备而设计的一种多叉(下面你会看到,相对于二叉,B树每个内结点有多个分支,即多叉)平衡查找树。 B 树又叫平衡多路查找树。一棵m阶的B 树 (m叉树)的特性如下: ...
  • wl6965307
  • wl6965307
  • 2016年06月20日 14:05
  • 17020

MySQL索引背后的数据结构及BTree B+Tree算法原理

摘要 本文以MySQL数据库为研究对象,讨论与数据库索引相关的一些话题。特别需要说明的是,MySQL支持诸多存储引擎,而各种存储引擎对索引的支持也各不相同,因此MySQL数据库支持多种索引类型,如B...
  • truelove12358
  • truelove12358
  • 2015年08月26日 16:43
  • 7981

BTree,B-Tree,B+Tree,B*Tree都是什么

B树、B-树、B+树、B*树都是什么 B树       即二叉搜索树:       1.所有非叶子结点至多拥有两个儿子(Left和Right);       2.所有结点存储一个关键字;       ...
  • b2b160
  • b2b160
  • 2009年10月20日 09:27
  • 2468
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Mysql-索引-BTree类型【精简】
举报原因:
原因补充:

(最多只允许输入30个字)