专栏持续更新中:MySQL详解
前言
在 MySQL 中, 索引是在存储引擎层实现的, 所以并没有统⼀的索引标准, 由于 InnoDB 存储引擎在 MySQL数据库中使⽤最为⼴泛, 下⾯以 InnoDB 为例来分析⼀下其中的索引模型.在 InnoDB 中, 表都是根据主键顺序以索引的形式存放的, InnoDB 使⽤了 B+ 树索引模型,所以数据都是存储在 B+ 树中的。
索引用来快速地寻找那些具有特定值的记录,所有MySQL索引都以B-树的形式保存。MySQL提供多种索引类型供选择:普通索引 、唯一性索引、主键索引 、全文索引等等。
下面本篇文章就来给大家介绍一下主键索引和普通索引之间的区别 ,希望对你们有所帮助。
分析
从图中可以看出, 根据叶子节点内容不同,索引类型分为主键索引和非主键索引.
- 主键索引也被称为聚簇索引,叶子节点存放的是整行数据;
- 而非主键索引被称为二级索引,叶子节点存放的是主键的值.
- 如果根据主键查询, 只需要搜索ID这颗B+树
- 而如果通过非主键索引查询, 需要先搜索k索引树, 找到对应的主键, 然后再到ID索引树搜索一次, 这个过程叫做回表.
主键索引
- 主键索引不可以为空
- 主键索引可以做外键
- 一张表中只能有一个主键索引
普通索引
- 用来加速数据访问速度而建立的索引。
- 多建立在经常出现在查询条件的字段和经常用于排序的字段。
- 被索引的数据列允许包含重复的值
唯一索引
被索引的数据列不允许包含重复的值
总结
非主键索引的查询需要多扫描一颗索引树, 效率相对更低.
- 普通索引是最基本的索引类型,没有任何限制,值可以为空,仅加速查询。普通索引是可以重复的,一个表中可以有多个普通索引。
- 主键索引是一种特殊的唯一索引,一个表只能有一个主键,不允许有空值;索引列的所有值都只能出现一次,即必须唯一。简单来说:主键索引是加速查询 + 列值唯一(不可以有null)+ 表中只有一个。