如何添加主键_mysql primary key设置

来源:这里教程网 时间:2026-02-28 20:42:59 作者:

在 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 引擎下,主键即聚簇索引,直接影响数据物理存储顺序,对性能影响显著

相关推荐