使用多列作为mysql的唯一标识符
我有一个包含以下各列的mysql表:
group_idgame_id
user_id
message
last_update
我想使其不存在任何两行,其中行x的group_id的值等于行y的group_id的值,行x的user_id的值也等于行y的user_id的值。
因此,例如,假设我插入以下值:
group_id = 783game_id = 34
user_id = 29237
message = none
last_update = 11233452
上面的数据,即使一个mysql查询试图插入它,如果已经存在具有group_id和user_id相同组合的行,也不应创建新行。有没有办法做到这一点?基本上,我试图使两列协同工作,就像一个唯一索引一样。
回答:
是的,MySQL提供了执行此操作的功能。
ALTER TABLE MyTableADD UNIQUE KEY `my_unique_key` (`group_id`, `user_id`)
我不知道您正在使用此表做什么,但听起来这个唯一键可能是该表主键的最佳选择。主键也自动是唯一键。如果您决定将其设置为主键,请执行以下操作:
ALTER TABLE MyTableADD PRIMARY KEY (`group_id`, `user_id`)
(如果收到错误消息,提示已经存在主键,请发出ALTER TABLE MyTable DROP PRIMARY KEY
然后重复上述命令。)
回应用户评论
NULL
对于唯一键覆盖的列,不能有多个具有相同非值的行。因此group_id = 0 AND user_id =
5,例如,您不能有两行。0是一个值。但是,如果使一列或两列 空,则
包含多行,直到NULL
s的位置相同。因此,您可以在其中拥有两行(或更多行)group_id IS NULL AND user_id = 1234
。
Proviso:以上对于两个常用的MySQL存储引擎(MyISAM和InnoDB)都是正确的。MySQL确实有NULL
被视为唯一值的存储引擎,但是您可能没有使用它们。
如果将一列或两列设置为可空,则唯一键不能为主键-主键必须位于的列上NOT NULL
。
假设您已将此键设为主键,现在想NULL
在该group_id
列中允许。我不知道目前group_id
是什么数据类型。我假设它是current
INT UNSIGNED NOT NULL
,但是如果不是这个,则必须修改以下内容。您将不再能够将此键用作主键。这是您可以运行以进行所需更改的命令:
ALTER TABLE MyTable DROP PRIMARY KEY,
MODIFY group_id INT UNSIGNED,
ADD UNIQUE KEY `my_unique_key_with_nulls` (`group_id`, `user`)
以上是 使用多列作为mysql的唯一标识符 的全部内容, 来源链接: utcz.com/qa/403143.html