ALTER TABLE添加一个复合主键

我有一个名为provider的表。 我有三列叫人, placething 。 可能有重复的人物,重复的地方和重复的事物,但是永远不会有一个重复的人物事物组合。

我将如何使用这三列在ALTER TABLE中为这个表添加一个组合主键?

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

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

 ALTER TABLE provider DROP PRIMARY KEY, ADD PRIMARY KEY(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). 

如果您想要删除另一个表所引用的主键,则必须首先将其他表中的外键删除。 如果在重新创build主键后仍然需要外键,则可以重新创build该外键。

另外,使用复合键时,顺序很重要。 这些

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

不是一回事。 他们都强调这三个领域的独特性,但从索引的angular度来看,是有区别的。 字段从左到右索引。 例如,请考虑以下查询:

 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中的主键索引
A可以使用ALTER语句2中的主键索引
C可以使用任一索引
D不能使用任何索引

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

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

看到这里的MySQL文档了解更多信息。

你可能只想要一个唯一的约束。 特别是如果你已经有一个代理键。 (例如:一个AUTO_INCREMENT)

 ALTER TABLE `MyDatabase`.`Provider` ADD CONSTRAINT CK_Per_Place_Thing_Unique UNIQUE (person,place,thing) ; 
 alter table table_name 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);

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