0

0

mysql唯一索引与普通索引区别_mysql索引类型解析

P粉602998670

P粉602998670

发布时间:2026-01-12 09:03:08

|

701人浏览过

|

来源于php中文网

原创

绝大多数等值查询下唯一索引和普通索引性能几乎无差别,核心区别在于唯一索引由数据库强制校验重复值以保障数据一致性,而普通索引仅加速查询且允许重复插入。

mysql唯一索引与普通索引区别_mysql索引类型解析

唯一索引和普通索引,查得一样快,但语义完全不同

直接说结论:**绝大多数等值查询(WHERE column = ?)下,唯一索引和普通索引的性能几乎没差别**。B+树定位到数据页后,InnoDB 都是把整页读进内存再二分查找;唯一索引多做的只是「找到第一个就停」,普通索引要多判断一次下一行是否还匹配——这个开销在 16KB 数据页里基本可忽略。

但关键不在快不快,而在「数据库是否帮你拦住脏数据」:

  • 普通索引 INDEX:只加速查询,允许重复值插入,哪怕你重复插 100 次手机号 '13800138000',MySQL 也照收不误
  • 唯一索引 UNIQUE:一旦定义,MySQL 会在 INSERTUPDATE 时自动校验——发现重复就报错 ERROR 1062 (23000): Duplicate entry 'xxx' for key 'idx_phone'
  • 注意:UNIQUE 允许 NULL,且多个 NULL 不算重复(这是 SQL 标准行为)

什么时候必须用唯一索引?不是“想快一点”,而是“不能错”

典型场景就是业务上天然要求字段全局唯一,且你不想靠应用层反复查库再插入(容易并发冲突):

  • 用户表的 id_cardemailusername
  • 订单表的 out_trade_no(外部交易号)
  • 设备表的 sn(序列号)
  • 防重场景:比如限制同一用户每天只能提交一条反馈,可建联合唯一索引 UNIQUE(user_id, DATE(created_at))

别图省事只加普通索引再靠代码 try-catch 插入失败——这会把数据一致性压力全推给应用,且并发下极易漏判。

网趣购物系统多用户升级版
网趣购物系统多用户升级版

多用户升级版完美整合北京网银、NPS支付、云网支付、快钱支付、西部支付,同时完美整合支付宝功能,是目前国内多用户版最优秀的开店平台,新版同时整合Ewebedit编辑器,增加搜索引擎关键词设置等,!多用户升级版与上一版本有着本质的区别,程序无论在功能性、安全性以及用户使用习惯上有了更高的提升。多用户版除了具有普通网店的所有功能之外,同时允许其他用户在此平台上开设店铺,类似淘宝的功能,是目前电子商务领

下载

建索引时写错关键字,后果很隐蔽

常见错误不是语法报错,而是「你以为建了唯一索引,其实建成了普通索引」:

  • 错:用 CREATE INDEX idx_email ON users(email); → 普通索引,无唯一约束
  • 对:用 CREATE UNIQUE INDEX idx_email ON users(email); → 真正生效的唯一索引
  • 更隐蔽的错:已有普通索引,又执行 ALTER TABLE users ADD UNIQUE(email); → 这条语句会失败(如果已有重复值),但很多人没检查返回值,误以为成功
  • 验证是否真建成了唯一索引:
    SHOW INDEX FROM users WHERE Key_name = 'idx_email';
    Non_unique 列:0 = 唯一索引,1 = 普通索引

唯一索引会影响 INSERT/UPDATE 性能?要看场景

唯一索引确实需要额外做「是否存在」校验,但实际影响有限:

  • 如果该值大概率不存在(如新用户注册填新邮箱),校验成本≈一次主键查询,通常 0.1ms 级别
  • 如果该值大概率已存在(如高频重试插入同一订单号),唯一索引反而更快——它不用走 change buffer(普通索引在非聚集页更新时依赖 change buffer 缓存写),直接命中页就判断并拒绝
  • 真正拖慢写入的,往往是索引太多、字段太长、或没走索引导致全表扫描校验(比如在没索引的列上加唯一约束)

所以别为了“怕慢”放弃唯一性保障;先确保字段上有对应索引,再谈优化。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

676

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

320

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

346

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1094

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

357

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

675

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

571

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

414

2024.04.29

c++主流开发框架汇总
c++主流开发框架汇总

本专题整合了c++开发框架推荐,阅读专题下面的文章了解更多详细内容。

97

2026.01.09

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 1.7万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 785人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号