MySQL中添加主键需在建表时用PRIMARY KEY定义单字段或联合主键,或对已有表用ALTER TABLE ADD PRIMARY KEY;不支持直接修改,须先DROP再ADD;主键字段须非空唯一,建议用稳定自增字段,InnoDB下主键即聚簇索引。

在 MySQL 中添加主键(PRIMARY KEY)是确保表中每条记录唯一性的关键操作。主键可以是一个字段,也可以是多个字段的组合(联合主键),且一个表只能有一个主键,其值不允许为 NULL。
创建表时直接定义主键
这是最常用的方式,在 CREATE TABLE 语句中通过 PRIMARY KEY 关键字指定:
- 单字段主键:将
PRIMARY KEY放在字段定义后,或单独写在表定义末尾 - 联合主键:用括号列出多个字段,如
PRIMARY KEY (id, category_id)
示例:
CREATE TABLE users ( id INT AUTO_INCREMENT, username VARCHAR(50) NOT NULL, email VARCHAR(100), PRIMARY KEY (id) );
给已有表添加主键
使用 ALTER TABLE ... ADD PRIMARY KEY 语法。注意:目标字段必须满足主键要求(非空、唯一、无重复值)。
- 单字段主键:
ALTER TABLE users ADD PRIMARY KEY (id); - 联合主键:
ALTER TABLE orders ADD PRIMARY KEY (order_id, product_id); - 若字段含 NULL 或重复数据,需先清理(如用
UPDATE补全、DELETE去重)再执行
修改主键(替换或删除后重建)
MySQL 不支持直接修改主键,但可通过“删除 + 新增”实现:
- 先删除原主键:
ALTER TABLE users DROP PRIMARY KEY; - 再添加新主键:
ALTER TABLE users ADD PRIMARY KEY (username); - 注意:如果原主键是自增列(
AUTO_INCREMENT),删除后该属性也会丢失,需重新指定
常见注意事项
避免踩坑的关键点:
- 主键字段建议设为
NOT NULL(即使不显式声明,MySQL 也会自动加上) - 尽量选用稳定、无业务含义的字段(如自增
INT或BIGINT)作主键,避免用手机号、邮箱等可能变更的数据 - 联合主键会增加索引体积和查询复杂度,仅在逻辑上确实需要多字段唯一约束时才使用
- InnoDB 引擎下,主键即聚簇索引,直接影响数据物理存储顺序,对性能影响显著










