您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

使用多列作为mysql的唯一标识符

使用多列作为mysql的唯一标识符

是的,MysqL提供了执行此操作的功能

ALTER TABLE MyTable
ADD UNIQUE KEY `my_unique_key` (`group_id`, `user_id`)

我不知道您正在使用此表做什么,但听起来这个唯一键可能是该表主键的最佳选择。主键也自动是唯一键。如果您决定将其设置为主键,请执行以下操作:

ALTER TABLE MyTable
ADD PRIMARY KEY (`group_id`, `user_id`)

(如果收到错误消息,提示已经存在主键,请发出ALTER TABLE MyTable DROP PRIMARY KEY然后重复上述命令。)

回应用户评论

NULL对于唯一键覆盖的列,不能有多个具有相同非值的行。因此group_id = 0 AND user_id = 5,例如,您不能有两行。0是一个值。但是,如果使一列或两列 空,则 包含多行,直到NULLs的位置相同。因此,您可以在其中拥有两行(或更多行)group_id IS NULL AND user_id = 1234

Proviso:以上对于两个常用的MysqL存储引擎(MyISAM和InnoDB)都是正确的。MysqL确实有NULL被视为唯一值的存储引擎,但是您可能没有使用它们。

如果将一列或两列设置为可空,则唯一键不能为主键-主键必须位于的列上NOT NULL

假设您已将此键设为主键,现在想NULL在该group_id列中允许。我不知道目前group_id是什么数据类型。我假设它是currentINT 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 2022/1/1 18:19:39 有472人围观

撰写回答


你尚未登录,登录后可以

和开发者交流问题的细节

关注并接收问题和回答的更新提醒

参与内容的编辑和改进,让解决方法与时俱进

请先登录

推荐问题


联系我
置顶