内容简介:索引类型包括 B-Tree、哈希索引、R-Tree、全文索引等,这里主要总结 B-Tree 和哈希索引。以 B-Tree 为结构的索引是最常见的索引类型,比如 InnoDB 和 MyISAM 都是以 B-Tree 为索引结构的索引,事实上是以 B+ Tree 为索引结构,B-Tree 和 B+Tree 区别在于,B+ Tree 在叶子节点上增加了顺序访问指针,方便叶子节点的范围遍历。这里主要介绍一下 InnoDB 和 MyISAM 两种不同的索引。InnoDB 也叫做聚簇索引,这个名字跟它本身的存储方式有
索引类型包括 B-Tree、哈希索引、R-Tree、全文索引等,这里主要总结 B-Tree 和哈希索引。
B-Tree 索引
以 B-Tree 为结构的索引是最常见的索引类型,比如 InnoDB 和 MyISAM 都是以 B-Tree 为索引结构的索引,事实上是以 B+ Tree 为索引结构,B-Tree 和 B+Tree 区别在于,B+ Tree 在叶子节点上增加了顺序访问指针,方便叶子节点的范围遍历。这里主要介绍一下 InnoDB 和 MyISAM 两种不同的索引。
InnoDB
InnoDB 也叫做聚簇索引,这个名字跟它本身的存储方式有关系,“聚簇“表示数据行和相邻的键值存储在一起,简单的说,就是叶子节点中存储的实际是真实的数据。InnoDB 通过主键聚集数据,所以一个表只能有一个聚簇索引,且必须有主键,如果没有定义主键,且不存在非空索引可以代替,InnoDB 会隐式定义一个主键作为聚簇索引。
聚簇索引的二级索引存储的不是指向行的物理位置的指针,而是行的主键值,所以如果通过二级索引查找行,需要找到二级索引的叶子结点获得对应的主键值,然后再去查找对应的行。对于 InnoDB,自适应哈希索引可以减少这样的重复工作。
MyISAM
MyISAM 也叫非聚簇索引,和 InnoDB 的区别在于,叶子结点上存的是指向对应行的物理地址,也就是说索引和数据实际是分开存储的。
MyISAM 采用了前缀压缩技术,从而使得更多索引可以放入到内存中,默认只压缩字符串,但是通过参数设置也可以对整数做压缩。压缩方法为,完整保存索引块中的第一个IE之,然后将其他值和第一个值进行比较得到相同前缀的字节数和剩余的不同后缀部分,把这部分存储起来即可。例如,索引块中的第一个值是”perform“,第二个值是”performance“,那么第二个值的前缀压缩后存储的是类似”7,ance“这样的形式。MyISAM 对行指针也采用类似的前缀压缩方式。
压缩可以使索引使用更少的空间,在某种程度上性能有所提升,但是代价是某些操作可能更慢。因为每个值的压缩前缀都依赖前面的值,所以 MyISAM 查找时无法在索引块使用二分查找,只能从头开始扫描,正序扫描速度还不错,逆序扫描的话查找某一行的操作平均都需要扫描半个索引块。对于 CPU 密集型应用,扫描需要随机查找,所以压缩索引会使得索引查找慢很多,而对于 I/O 密集型应用,对于某些查询的优化更明显。
锁
InnoDB 使用的是行锁,所以支持事务,而 MyISAM 使用的是表锁,不支持事务。
适用范围
B-Tree 索引适用于区间查询,因为 B-Tree 存储后的叶子节点本身就是有序的,并且 B+ Tree 结构还增加了叶子节点的连续顺序指针,对于区间查询来说就更加方便了。
哈希索引
哈希索引是基于哈希表实现的,只有精确匹配索引所有列的查询才有效。方法是,对所有的索引列计算一个 hash code,hash code 作为索引,在哈希表中保存指向每个数据行的指针。
优点
- 索引本身只存储 hash code,所以结构很紧凑,并且查找速度很快
限制
- 索引中的 hash code 是顺序存储的,但是 hash code 对应的数据并不是顺序的,所以无法用于排序
- 不支持部分索引列匹配查找,因为哈希索引是使用索引列的全部内容来计算 hash code
- 只支持等值比较,不支持范围查询
- 如果哈希冲突严重时,必须遍历链表中所有行指针
- 哈希冲突严重的话,索引维护操作的代价也很高
InnoDB 的自适应哈希索引
首先,请注意,自适应哈希索引对于用户来说是无感知的,这是一个完全自动、内部的行为,用户无法控制或者配置,但是可以关闭。
当 InnoDB 注意到某个索引值被使用的非常频繁时,它会在内存中基于 B-Tree 索引之上再创建一个哈希索引,这样 B-Tree 也可以具有哈希索引的一些优点,比如快速的哈希查找。
当然如果存储引擎不支持哈希索引,用户也可以自定义哈希索引,这样性能会比较高,缺陷是需要自己维护哈希值,如果采用这种方法,不要使用 SHA1()
和 MD5()
作为哈希函数,因为这两个是强加密函数,设计目标是最大限度消除冲突,生成的 hash code 是一个非常长的字符串,浪费大量的空间,哈希索引中对于索引的冲突要求没有那么高。
以上所述就是小编给大家介绍的《MySQL 笔记 - 索引类型》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- Mysql索引优化(一)_索引类型
- MongoDB指南---13、索引类型
- MySQL 索引的原理与应用:索引类型,存储结构与锁
- 聊一聊 InnoDB 引擎中的索引类型
- Nebula Graph v2.0 GA,支持全文索引和 String 类型 VID
- Oracle字符类型存数字及查询数字时使用单引号走不走索引的问题
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。