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);
UPDATE 补全、DELETE 去重)再执行MySQL 不支持直接修改主键,但可通过“删除 + 新增”实现:
ALTER TABLE users DROP PRIMARY KEY;
ALTER TABLE users ADD PRIMARY KEY (username);

AUTO_INCREMENT),删除后该属性也会丢失,需重新指定避免踩坑的关键点:
NOT NULL(即使不显式声明,MySQL 也会自动加上)INT 或 BIGINT)作主键,避免用手机号、邮箱等可能变更的数据