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

专栏持续更新中:MySQL详解

前言

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

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

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

分析

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

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

主键索引

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

普通索引

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

唯一索引

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

总结

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

  • 普通索引是最基本的索引类型,没有任何限制,值可以为空,仅加速查询。普通索引是可以重复的,一个表中可以有多个普通索引。
  • 主键索引是一种特殊的唯一索引,一个表只能有一个主键,不允许有空值;索引列的所有值都只能出现一次,即必须唯一。简单来说:主键索引是加速查询 + 列值唯一(不可以有null)+ 表中只有一个。
相关推荐
前进的李工1 小时前
SQL聚合函数与分组查询详解
数据库·sql·mysql
上进小菜猪1 小时前
基于 YOLOv8 的驾驶员疲劳状态识别系统实战(含完整源码与可视化界面)
后端
Nonoas2 小时前
动态代理:发布订阅的高级玩法
java·ide·intellij-idea
上进小菜猪2 小时前
基于 YOLOv8 的交通标识与设施识别系统(含完整源码)
后端
程序员-周李斌2 小时前
Java 死锁
java·开发语言·后端
布列瑟农的星空2 小时前
还在手动翻译国际化词条?AST解析+AI翻译实现一键替换
前端·后端·ai编程
2301_800050993 小时前
mysql
数据库·笔记·mysql
武子康3 小时前
大数据-197 K折交叉验证实战:sklearn 看均值/方差,选更稳的 KNN 超参
大数据·后端·机器学习
数据皮皮侠3 小时前
2m气温数据集(1940-2024)
大数据·数据库·人工智能·制造·微信开放平台
皮皮林5513 小时前
Prometheus+Grafana,打造强大的监控与可视化平台
java