mysql - ALTER TABLE添加复合主键

我有一个叫provider的表,有三列: person,place,thing ,可以有重复的人,重复的地方,重复的东西,但是,永远不会有重复的人,地方,东西的组合。

如何修改表以在MySQL中添加这三个列的复合主键?

时间:


ALTER TABLE provider ADD PRIMARY KEY(person,place,thing);

如果主键已经存在,那么你想这样做


ALTER TABLE provider DROP PRIMARY KEY, ADD PRIMARY KEY(person, place, thing);

你可能只需要一个唯一的约束,尤其是如果你已经有一个surrogate键,(示例:auto_increment )


ALTER TABLE `MyDatabase`.`Provider`
 ADD CONSTRAINT CK_Per_Place_Thing_Unique UNIQUE (person,place,thing)
;

然而,要删除现有的主键还有另一个,如果主键被另一个表用作外键,则在尝试删除它时会出现错误。 在某些版本的mysql中,错误消息出现错误(如5.5.17,此错误消息仍然存在),


alter table parent drop column id;
ERROR 1025 (HY000): Error on rename of
'./test/#sql-a04_b' to './test/parent' (errno: 150).

如果要删除另一个表引用的主键,则必须先删除其他表中的外键,如果你仍然需要重新创建主键之后,你可以重新创建该外键。

同时,在使用组合键时,顺序很重要。 这些


1) ALTER TABLE provider ADD PRIMARY KEY(person,place,thing);
and
2) ALTER TABLE provider ADD PRIMARY KEY(person,thing,place);

是不一样的,它们都强制在三个字段的集合上执行唯一性,但是,从索引的角度来看,字段从左到右索引,例如请考虑以下查询:


A) SELECT person, place, thing FROM provider WHERE person = 'foo' AND thing = 'bar';
B) SELECT person, place, thing FROM provider WHERE person = 'foo' AND place = 'baz';
C) SELECT person, place, thing FROM provider WHERE person = 'foo' AND place = 'baz' AND thing = 'bar';
D) SELECT person, place, thing FROM provider WHERE place = 'baz' AND thing = 'bar';

B可以使用ALTER语句1中的主键索引
可以使用ALTER语句2中的主键索引
C可以使用任意索引
D不能使用任何索引

A使用索引2中的前两个字段作为部分索引。因为索引不知道索引的中间位置部分,所以,不能使用索引1,尽管如此,它仍然可以使用部分索引。

D不能使用任何一个索引,因为它不了解人。

在这里查看mysql文档以获得更多信息


alter table table_name add primary key (col_name1, col_name2);

ALTER TABLE table_name DROP PRIMARY KEY,ADD PRIMARY KEY (col_name1, col_name2);

使用COMPOSITE UNIQUE KEY肯定会更好,正如@GranadaCoder提供的那样,虽然有点棘手:

ALTER IGNORE TABLE table_name ADD UNIQUES INDEX idx_name(some_id, another_id, one_more_id);

...