栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

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

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

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

是的,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`)


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/421270.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号