mysql主键是什么_mysql主键作用与设置方法

发布时间 - 2026-01-21 00:00:00    点击率:
MySQL主键是强制指定的唯一标识字段,必须非空且唯一;InnoDB中主键即聚簇索引,决定数据物理存储,影响查询性能与写入效率;建表时应优先定义自增整数主键,避免业务字段或UUID;大表补主键需谨慎处理空值、重复值并避开高峰期。

主键就是表里那个“身份证号”

MySQL 主键(PRIMARY KEY)不是可有可无的装饰,而是数据库强制要求你为每张表指定的唯一标识字段(或字段组合)。它必须满足两个铁律:NOT NULL(不能为 NULL)和 UNIQUE(整张表内绝不重复)。比如一张 users 表,用 id 字段当主键,插入时若漏填、填重复、或填

NULL,MySQL 会直接报错:ERROR 1048 (23000): Column 'id' cannot be nullERROR 1062 (23000): Duplicate entry '1' for key 'PRIMARY'

为什么非设不可?关键在 InnoDB 的聚簇索引

如果你用的是默认存储引擎 InnoDB(绝大多数情况都是),主键就决定了整张表数据怎么物理存放。InnoDB 把数据直接存在主键索引的叶子节点上——这叫聚簇索引(Clustered Index)。这意味着:

  • 按主键查询最快,通常 1–3 次磁盘 I/O 就能定位到行;
  • 没有主键时,InnoDB 会悄悄生成一个隐藏的 GEN_CLUST_INDEX(6 字节 rowid),但这个 ID 对业务完全不可控,且无法用于外键或显式查询;
  • 如果主键是自增整数(如 BIGINT AUTO_INCREMENT),新记录基本追加写入,避免页分裂;而用 UUID 或字符串作主键,容易导致随机插入、频繁页分裂,性能明显下降。

怎么设主键?建表时最稳妥

推荐在 CREATE TABLE 时一次性定义主键,避免后期修改引发锁表或数据迁移。常见写法:

CREATE TABLE orders (
  id BIGINT UNSIGNED NOT NULL AUTO_INCREMENT,
  order_no VARCHAR(32) NOT NULL,
  created_at DATETIME DEFAULT CURRENT_TIMESTAMP,
  PRIMARY KEY (id),
  UNIQUE KEY uk_order_no (order_no)
);

注意几个硬约束:

  • AUTO_INCREMENT 字段必须是主键(或主键的一部分),且只能有一个;
  • 类型推荐 INTBIGINT UNSIGNED(避免负值干扰);
  • 不要用带业务含义的字段(比如 phoneemail)当主键——它们可能变更、被回收、或涉及隐私合规问题;
  • 联合主键(如 PRIMARY KEY (user_id, product_id))可行,但会加大二级索引体积,且 INSERT / UPDATE 语句更易出错,日常开发中尽量避免。

已有表补主键?小心锁表和数据冲突

对大表执行 ALTER TABLE t ADD PRIMARY KEY (id) 是高危操作:MySQL 会重建整张表(copy & rebuild),期间表被锁,写入阻塞。更麻烦的是,如果该字段已有 NULL 值或重复值,命令会直接失败,必须先清理:

  • 查空值:SELECT COUNT(*) FROM t WHERE id IS NULL;
  • 查重复:SELECT id, COUNT(*) FROM t GROUP BY id HAVING COUNT(*) > 1;
  • 补全空值(如用自增模拟):SET @row := 0; UPDATE t SET id = (@row := @row + 1) WHERE id IS NULL;(慎用,需提前备份)

线上大表务必在低峰期操作,并确认 binlog 格式为 ROW,否则主从延迟可能飙升。

主键看着简单,但它牵一发而动全身——既是数据安全的底线,也是查询性能的基石。很多人只记得加 AUTO_INCREMENT,却忽略类型选择、是否允许负数、以及隐式聚簇行为带来的写放大问题。这些细节,往往在百万级数据量时才突然暴露。


# mysql  # 字节  # ai  # 为什么  # red  # NULL  # count  # for  # select  # Error  # 字符串  # int  # copy  # column  # table  # 数据库  # 主键  # 的是  # 整张  # 已有  # 都是  # 看着  # 几个  # 就能  # 很多人  # 线上 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 小视频制作网站有哪些,有什么看国内小视频的网站,求推荐?  Laravel Pest测试框架怎么用_从PHPUnit转向Pest的Laravel测试教程  网站制作大概多少钱一个,做一个平台网站大概多少钱?  如何用已有域名快速搭建网站?  Laravel如何使用Service Container和依赖注入?(代码示例)  Android实现代码画虚线边框背景效果  Laravel如何使用Contracts(契约)进行编程_Laravel契约接口与依赖反转  HTML5段落标签p和br怎么选_文本排版常用标签对比【解答】  Java遍历集合的三种方式  Laravel队列任务超时怎么办_Laravel Queue Timeout设置详解  焦点电影公司作品,电影焦点结局是什么?  Laravel怎么防止CSRF攻击_Laravel CSRF保护中间件原理与实践  香港服务器租用每月最低只需15元?  网站建设整体流程解析,建站其实很容易!  Laravel如何发送系统通知?(Notification渠道示例)  大连网站制作公司哪家好一点,大连买房网站哪个好?  如何在云虚拟主机上快速搭建个人网站?  Laravel如何使用Livewire构建动态组件?(入门代码)  javascript读取文本节点方法小结  Laravel怎么实现微信登录_Laravel Socialite第三方登录集成  如何在新浪SAE免费搭建个人博客?  Laravel软删除怎么实现_Laravel Eloquent SoftDeletes功能使用教程  Laravel PHP版本要求一览_Laravel各版本环境要求对照  如何在景安服务器上快速搭建个人网站?  高防服务器租用指南:配置选择与快速部署攻略  家族网站制作贴纸教程视频,用豆子做粘帖画怎么制作?  北京网站制作公司哪家好一点,北京租房网站有哪些?  如何在企业微信快速生成手机电脑官网?  在线教育网站制作平台,山西立德教育官网?  如何基于云服务器快速搭建网站及云盘系统?  西安市网站制作公司,哪个相亲网站比较好?西安比较好的相亲网站?  在线ppt制作网站有哪些软件,如何把网页的内容做成ppt?  如何用腾讯建站主机快速创建免费网站?  简单实现Android文件上传  如何在云主机上快速搭建网站?  Laravel Livewire是什么_使用Laravel Livewire构建动态前端界面  夸克浏览器网页跳转延迟怎么办 夸克浏览器跳转优化  智能起名网站制作软件有哪些,制作logo的软件?  如何在 Telegram Web View(iOS)中防止键盘遮挡底部输入框  创业网站制作流程,创业网站可靠吗?  Laravel如何创建自定义Artisan命令?(代码示例)  深圳网站制作公司好吗,在深圳找工作哪个网站最好啊?  韩国网站服务器搭建指南:VPS选购、域名解析与DNS配置推荐  Laravel如何实现模型的全局作用域?(Global Scope示例)  谷歌浏览器如何更改浏览器主题 Google Chrome主题设置教程  Edge浏览器怎么启用睡眠标签页_节省电脑内存占用优化技巧  再谈Python中的字符串与字符编码(推荐)  专业企业网站设计制作公司,如何理解商贸企业的统一配送和分销网络建设?  实例解析angularjs的filter过滤器  Laravel如何构建RESTful API_Laravel标准化API接口开发指南