美文网首页
数据库的索引BTree索引、Hash索引

数据库的索引BTree索引、Hash索引

作者: 十里染林 | 来源:发表于2020-09-10 10:41 被阅读0次

索引

索引是为了方便查找我们所需要的数据。

MySQL支持的索引数据类型

一、B-Tree索引的特点

B-Tree索引以B+Tree(树)的结构存储数据;
B-Tree索引能够加快数据的查询速度;
B-Tree更适合进行范围查找;

*在什么情况下可以用到B树索引

全值匹配的查询;
匹配最左前缀的查询;
匹配列前缀查询 ;
匹配范围值得查询;
精确匹配左前列并范围匹配另外一列;
只访问索引的查询;

BTree索引的限制:

如果不是按照索引的最左列开始查找,则无法使用索引;
使用索引时不能跳过索引中的列;
Not in 和<>操作无法使用索引;
如果查询中有某个列的范围查询,则其右边所有的列都无法使用索引;

二、Hash索引的特点

Hash索引时基于Hash表实现的,只有查询条件精确匹配Hash索引中的所有列时,才能够使用到Hash索引

对于Hash索引中的所有列,存储引擎都会为每一行计算一个Hash码,Hash索引中存储的就是Hash码

Hash索引的限制:

Hash索引必须进行二次查找;
Hash索引无法用于排序;
Hash索引不支持部分索引查找也不支持范围查找;
Hash索引中Hash码的计算可能存在Hash冲突;

*索引的优点:

  1. 索引大大减少了存储引擎需要扫描的数据量,缩短数据的检索时间
  2. 索引可以帮助我们进行排序避免使用临时表
  3. 索引可以把随机I/O变为顺序I/O

*索引的缺点:

  1. 索引会增加写操作成本,降低表的增删改效率,因为每次增删改索引需要进行动态维护,导致时间变长
  2. 太多的索引会增加查询优化器的选择时间
  3. 创建索引和维护索引需要空间成本,数据量越大,占用空间也越大

*什么情况下需要建立索引:

  1. 数据量大,经常进行查询操作的表
  2. 用于排序的字段可以添加索引,用于分组的字段根据需要添加索引
  3. 表与表连接用于多表联合查询约束条件的字段应当建立索引

相关文章

  • 温故知新-MYSQL-索引基础

    概念 分类:主键索引、唯一索引、普通索引、组合索引、全文索引 算法:Btree,hash 区别:hash只能用于=...

  • 索引概述

    索引是数据库查询提高性能的最常用的工具。可以把索引类比成书的目录。索引类型:hash索引和btree索引。MyIS...

  • 索引

    MySQL索引原理及慢查询优化 索引的储存分类: BTREE索引和HASH索引。MyISAM 和 InnoDB 存...

  • MySQL索引

    一、 MySQL: 索引以B树格式保存 Memory存储引擎可以选择Hash或BTree索引,Hash索引只能用于...

  • MySQL面试题 | 附答案解析(四)

    7. 索引算法有哪些? 索引算法有 BTree算法和Hash算法 BTree算法 BTree是最常用的mysql数...

  • Mysql索引与锁

    本文以Mysql5.7为例测试。 1:mysql索引方法 Mysql的索引方法分为btree索引和hash索引。 ...

  • 索引原理-btree索引与hash索引的区别

    btree索引与hash索引的区别,之前不清楚,mark一下。Hash 索引结构的特殊性,其检索效率非常高,索引的...

  • 索引原理-btree索引与hash索引的区别

    btree索引与hash索引的区别,之前不清楚,mark一下。 Hash索引结构的特殊性,其检索效率非常高,索引的...

  • 数据库的索引BTree索引、Hash索引

    索引 索引是为了方便查找我们所需要的数据。 MySQL支持的索引数据类型 一、B-Tree索引的特点 B-Tree...

  • MySQL的数据库索引优化

    1.Btree索引和Hash索引 MySQL支持的索引类型: B-tree索引的特点: B-tree索引以B+树的...

网友评论

      本文标题:数据库的索引BTree索引、Hash索引

      本文链接:https://www.haomeiwen.com/subject/brguektx.html