【面试】Mysql主键索引普通索引索引和唯一索引的区别是什么?

专栏持续更新中:MySQL详解

前言

在 MySQL 中, 索引是在存储引擎层实现的, 所以并没有统⼀的索引标准, 由于 InnoDB 存储引擎在 MySQL数据库中使⽤最为⼴泛, 下⾯以 InnoDB 为例来分析⼀下其中的索引模型.在 InnoDB 中, 表都是根据主键顺序以索引的形式存放的, InnoDB 使⽤了 B+ 树索引模型,所以数据都是存储在 B+ 树中的。

索引用来快速地寻找那些具有特定值的记录,所有MySQL索引都以B-树的形式保存。MySQL提供多种索引类型供选择:普通索引 、唯一性索引、主键索引 、全文索引等等。

下面本篇文章就来给大家介绍一下主键索引和普通索引之间的区别 ,希望对你们有所帮助。

分析

从图中可以看出, 根据叶子节点内容不同,索引类型分为主键索引和非主键索引.

  • 主键索引也被称为聚簇索引,叶子节点存放的是整行数据;
  • 而非主键索引被称为二级索引,叶子节点存放的是主键的值.
  • 如果根据主键查询, 只需要搜索ID这颗B+树
  • 而如果通过非主键索引查询, 需要先搜索k索引树, 找到对应的主键, 然后再到ID索引树搜索一次, 这个过程叫做回表.

主键索引

  • 主键索引不可以为空
  • 主键索引可以做外键
  • 一张表中只能有一个主键索引

普通索引

  • 用来加速数据访问速度而建立的索引。
  • 多建立在经常出现在查询条件的字段和经常用于排序的字段。
  • 被索引的数据列允许包含重复的值

唯一索引

被索引的数据列不允许包含重复的值

总结

非主键索引的查询需要多扫描一颗索引树, 效率相对更低.

  • 普通索引是最基本的索引类型,没有任何限制,值可以为空,仅加速查询。普通索引是可以重复的,一个表中可以有多个普通索引。
  • 主键索引是一种特殊的唯一索引,一个表只能有一个主键,不允许有空值;索引列的所有值都只能出现一次,即必须唯一。简单来说:主键索引是加速查询 + 列值唯一(不可以有null)+ 表中只有一个。
相关推荐
CHENWENFEIc1 分钟前
SpringBoot论坛系统安全测试实战报告
spring boot·后端·程序人生·spring·系统安全·安全测试
秦歌6666 分钟前
向量数据库-Milvus快速入门
数据库·milvus
高兴达8 分钟前
RPC--Netty客户端实现
java·spring·rpc
重庆小透明34 分钟前
力扣刷题记录【1】146.LRU缓存
java·后端·学习·算法·leetcode·缓存
lang2015092839 分钟前
Reactor操作符的共享与复用
java
TTc_1 小时前
@Transactional事务注解的批量回滚机制
java·事务
博观而约取1 小时前
Django 数据迁移全解析:makemigrations & migrate 常见错误与解决方案
后端·python·django
Edingbrugh.南空1 小时前
Flink SQLServer CDC 环境配置与验证
数据库·sqlserver·flink
码不停蹄的玄黓2 小时前
MySQL分布式ID冲突详解:场景、原因与解决方案
数据库·分布式·mysql·id冲突
wei_shuo2 小时前
飞算 JavaAI 开发助手:深度学习驱动下的 Java 全链路智能开发新范式
java·开发语言·飞算javaai