MySQL 索引的所有叫法 索引有种类哪些 索引概念

在MySQL Innodb存储引擎中,索引就是数据,数据就是索引。

索引类型

  1. B+树索引:Innodb引擎使用,且内部都是此索引类型。
  2. Hash索引:基于哈希表实现,用于精确匹配索引所指向的数据。
  3. 全文索引:仅MyISAM引擎支持,主要用来查找文本中的关键字,而不是直接与索引中的值相比较。
  4. 自适应哈希索引:Innodb引擎使用,自动根据访问的频率建立的哈希索引。

索引种类

  1. 聚簇索引,也叫聚集索引、主键索引、一级索引。
  2. 非聚簇索引,也叫二级索引。

聚簇索引

一张表必须存在一个并且只存在一个,叶子节点存有行的所有列的数据。在建表时会生成一个聚簇索引,而这个聚簇索引就是维护数据的增删改查的地方,聚簇索引是一个B+树结构,所有叶子节点就是行数据。聚簇索引是用主键创建的。如果建表时没有创建主键,则使用唯一索引做主键,如果没有唯一索引,则底层生成一个隐藏的主键列。

非聚簇索引

非聚簇索引,叶子节点只有索引列和主键。

非聚簇索引又分为:

  1. 普通索引:单列索引,单个字段建成的索引。
  2. 唯一索引:列值唯一,不使用change buffer。
  3. 联合索引:也叫复合索引、组合索引,多个列组成的索引。
  4. 联合唯一索引:也叫复合唯一索引、组合唯一索引,多个列组成的唯一索引。

其他概念

  1. 回表:查询的值如果在索引中没有,则会回表:拿到主键值后去聚簇索引查询。可以使用覆盖索引避免回表,索引下推也可以减少回表次数。
  2. 覆盖索引:只需要通过索引就可以查询所有列的数据。需要在查询时只查询索引列,或建的索引列包含所有查询结果。
  3. 索引下推:简称ICP,在使用非聚簇索引进行条件过滤时,对索引中包含的字段先做条件判断,过滤掉不符合条件的记录,减少回表字数。MySQL5.6开始支持。
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值