B树系列在数据库中的应用

1.索引

**B-**树最常见的应用就是用来做索引。索引通俗的说就是为了方便用户快速找到所寻之物,比如:书籍目录可以让读者快速找到相关信息,hao123网页导航网站,为了让用户能够快速的找到有价值的分类网站,本质上就是互联网页面中的索引结构。

MySQL官方对索引的定义为:索引**(index)是帮助MySQL****高效获取数据的数据结构,简单来说:**索引就是数据结构

当数据量很大时,为了能够方便管理数据,提高数据查询的效率,一般都会选择将数据保存到数据库,因此数据库不仅仅是帮助用户管理数据,而且数据库系统还维护着满足特定查找算法的数据结构,这些数据结构以某种方式引用数据,这样就可以在这些数据结构上实现高级查找算法,该数据结构就是索引。

2.MySQL索引

mysql是目前非常流行的开源关系型数据库,不仅是免费的,可靠性高,速度也比较快,而且拥****有灵活的插件式存储引擎,如下:

MySQL中索引属于存储引擎级别的概念,不同存储引擎对索引的实现方式是不同的。
注意:索引是基于表的,而不是基于数据库的

2.1MyISAM

MyISAM引擎是MySQL5.5.8版本之前默认的存储引擎,不支持事物支持全文检索,使用B+Tree作为索引结构,叶节点的data域存放的是数据记录的地址(索引和数据是分开的) ,其结构如下:

2.2InnoDB

InnoDB****存储引擎支持事务,其设计目标主要面向在线事务处理的应用,从MySQL数据库5.5.8本开始,InnoDB存储引擎是默认的存储引擎。InnoDB支持B+树索引、全文索引、哈希索引。但 InnoDB使用B+Tree作为索引结构时,具体实现方式却与MyISAM截然不同。

第一个区别是InnoDB的数据文件本身就是索引文件。**MyISAM****索引文件和数据文件是分离的,**索引文件仅保存数据记录的地址。而InnoDB索引,表数据文件本身就是按B+Tree组织的一个索引结构,这棵树的叶节点data域保存了完整的数据记录。这个索引的key是数据表的主键,因此InnoDB表数据文件本身就是主索引。

第二个区别:增加普通索引,叶子节点不能直接映射主键索引对应的值,叶子节点存的是主键索引。

2.3总结

相关推荐
无尽的罚坐人生1 小时前
hot 100 543. 二叉树的直径
数据结构·算法·leetcode
七月初七771 小时前
使用Python连接MySQL数据库
数据库·python·mysql
悲伤小伞2 小时前
0-MySQL 在 Centos 7环境详细安装过程
linux·服务器·数据库·mysql·centos
Oscar的参数2 小时前
datagrip连接未预置数据库保姆级教程--以dm数据库为例
大数据·数据库·database
轻颂呀2 小时前
排序——堆排序
数据结构·算法
WolfGang0073212 小时前
代码随想录算法训练营 Day07 | 字符串 part01
数据结构·算法·leetcode
8Qi82 小时前
LeetCode61. 旋转链表
c语言·数据结构·c++·算法·leetcode·链表·力扣
海边的Kurisu2 小时前
范进说八股 | Redis篇
数据库·redis·缓存
難釋懷2 小时前
Redis主从-主从同步优化
数据库·redis·缓存