• 售前

  • 售后

热门帖子
入门百科

MySQL中的唯一性束缚与NULL详解

[复制链接]
甜言疯语 显示全部楼层 发表于 2021-10-25 18:47:42 |阅读模式 打印 上一主题 下一主题
媒介
之前做的一个需求,简化形貌下就是接受其他组的 MQ 的消息,然后在数据库里插入一条记录。为了防止他们重复发消息,插入多条重复记录,以是在表中的几个列上加了个唯一性索引。
  1. CREATE UNIQUE INDEX IDX_UN_LOAN_PLAN_APP ON testTable (A, B, C);
复制代码
这时 A,B,C 三列都是不允许 NULL 值的,唯一性约束也是 work 的。

厥后由于需求的变革,修改了以前的唯一性约束,又多加了一列。(至于为什么加就不赘述了)。
  1. ALTER TABLE testTable
  2. DROP INDEX IDX_UN_LOAN_PLAN_APP,
  3. ADD UNIQUE KEY `IDX_UN_LOAN_PLAN_APP` (A, B, C, D);
复制代码
新加的 D 是范例是 datetime, 允许为 NULL,默认值为 NULL。之以是默认值为 NULL,是思量到不是所有记录都有这个时间的, 如果强行设置一个 Magic Value (好比'1970-01-01 08:00:00‘)当做默认值,看起来很奇怪。
蓝后。。。就出标题了。加了 D 之后,唯一性约束基本就失效了。
  1. Insert into testTable (A,B,C,D) VALUES (1,2,3,NULL); --- OK
  2. Insert into testTable (A,B,C,D) VALUES (1,2,3,NULL); --- OK
  3. Insert into testTable (A,B,C,D) VALUES (1,2,3,NULL); --- OK
复制代码
上面的三条 SQL 都是可以实行成功的,数据库中会有多条一样的记录。可按照我们以前的构想,在实行后两条 SQL 时 应该抛出 ‘Duplicate key' 的非常的。
厥后查了一下,才发现其实 MySQL 官方文档上已经明白说了这一点, 唯一性索引是允许多个 NULL 值的存在的:
  1. A UNIQUE index creates a constraint such that all values in the index must be distinct. An error occurs if you try to add a new row with a key value that matches an existing row. For all engines, a UNIQUE index allows multiple NULL values for columns that can contain NULL.
复制代码
从下表中也可以看出来不管是采取什么范例的存储引擎,在建立 unique key 的时候都是允许多个 NULL 存在的。。。。


细想想,其实也蛮合理,究竟在 MySQL 中以为 NULL 代表着“未知”。 在 SQL 中,任何值与 NULL 的比力返回值都是 NULL 而不是 TRUE, 就算 NULL 与 NULL 的比力也是返回 NULL。
以是只能 fix 了。。。解决办法也蛮简单粗暴的,直接把线上数据刷了一遍,将“1970-01-01 08:00:00”作为默认值,然后把那列改为不允许为 NULL 的了,咳咳。
MySQL 官网上也有蛮多人讨论过这个标题,一部门人以为这是 MySQL 的 bug, 另一部门则以为是一个 feature,附上链接。
MySQL Bugs: #8173: unique index allows duplicates with null values
总结
以上就是这篇文章的全部内容了,希望本文的内容对各人的学习大概工作能带来肯定的资助,如果有疑问各人可以留言交流,谢谢各人对草根技术分享的支持。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?立即注册

x

帖子地址: 

回复

使用道具 举报

分享
推广
火星云矿 | 预约S19Pro,享500抵1000!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

草根技术分享(草根吧)是全球知名中文IT技术交流平台,创建于2021年,包含原创博客、精品问答、职业培训、技术社区、资源下载等产品服务,提供原创、优质、完整内容的专业IT技术开发社区。
  • 官方手机版

  • 微信公众号

  • 商务合作