• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    MySQL中的唯一性约束与NULL详解

    前言

    之前做的一个需求,简化描述下就是接受其他组的 MQ 的消息,然后在数据库里插入一条记录。为了防止他们重复发消息,插入多条重复记录,所以在表中的几个列上加了个唯一性索引。

    CREATE UNIQUE INDEX IDX_UN_LOAN_PLAN_APP ON testTable (A, B, C);

    这时 A,B,C 三列都是不允许 NULL 值的,唯一性约束也是 work 的。

    后来由于需求的变化,修改了以前的唯一性约束,又多加了一列。(至于为什么加就不赘述了)。

    ALTER TABLE testTable
    DROP INDEX IDX_UN_LOAN_PLAN_APP,
    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 之后,唯一性约束基本就失效了。

    Insert into testTable (A,B,C,D) VALUES (1,2,3,NULL); --- OK
    Insert into testTable (A,B,C,D) VALUES (1,2,3,NULL); --- OK
    Insert into testTable (A,B,C,D) VALUES (1,2,3,NULL); --- OK

    上面的三条 SQL 都是可以执行成功的,数据库中会有多条一样的记录。可按照我们以前的构想,在执行后两条 SQL 时 应该抛出 ‘Duplicate key' 的异常的。

    后来查了一下,才发现其实 MySQL 官方文档上已经明确说了这一点, 唯一性索引是允许多个 NULL 值的存在的:

    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

    总结

    以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。

    您可能感兴趣的文章:
    • 详解mysql不等于null和等于null的写法
    • Mysql NULL导致的神坑
    • MySQL中建表时可空(NULL)和非空(NOT NULL)的用法详解
    • mysql中null(IFNULL,COALESCE和NULLIF)相关知识点总结
    • MySQL中NOT IN填坑之列为null的问题解决
    • mysql字符串拼接并设置null值的实例方法
    • MySQL中NULL对索引的影响深入讲解
    • MySQL中可为空的字段设置为NULL还是NOT NULL
    • mysql中替代null的IFNULL()与COALESCE()函数详解
    • mysql 转换NULL数据方法(必看)
    • 区分MySQL中的空值(null)和空字符('''')
    上一篇:MySQL数据库操作的基本命令
    下一篇:Mac下安装mysql5.7.18的详细步骤
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    MySQL中的唯一性约束与NULL详解 MySQL,中的,唯一性,约束,