mysql给表增加联合主键_mysql - ALTER TABLE添加复合主键

@Adrian Cornish的回答是正确的。 但是,删除现有主键还有另一个警告。 如果该主键被另一个表用作外键,则在尝试删除它时会出错。 在某些版本的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中的主键索引

A可以使用ALTER语句2中的主键索引

C可以使用任一索引

D不能使用任何一个索引

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

D不能使用任何索引,因为它不知道人。

有关更多信息,请参阅此处的mysql文档。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值