欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL中的唯一性約束與NULL詳解

 更新時(shí)間:2017年05月20日 09:36:04   作者:Giraffe  
這里記錄的是很久之前的一個(gè) bug 了,主要給大家介紹了關(guān)于MySQL中唯一性約束與NULL的相關(guān)資料,文中介紹的非常詳細(xì),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起看看吧。

前言

之前做的一個(gè)需求,簡(jiǎn)化描述下就是接受其他組的 MQ 的消息,然后在數(shù)據(jù)庫(kù)里插入一條記錄。為了防止他們重復(fù)發(fā)消息,插入多條重復(fù)記錄,所以在表中的幾個(gè)列上加了個(gè)唯一性索引。

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

這時(shí) A,B,C 三列都是不允許 NULL 值的,唯一性約束也是 work 的。

后來(lái)由于需求的變化,修改了以前的唯一性約束,又多加了一列。(至于為什么加就不贅述了)。

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,默認(rèn)值為 NULL。之所以默認(rèn)值為 NULL,是考慮到不是所有記錄都有這個(gè)時(shí)間的, 如果強(qiáng)行設(shè)置一個(gè) Magic Value (比如'1970-01-01 08:00:00‘)當(dāng)做默認(rèn)值,看起來(lái)很奇怪。

藍(lán)后。。。就出問(wèn)題了。加了 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 都是可以執(zhí)行成功的,數(shù)據(jù)庫(kù)中會(huì)有多條一樣的記錄??砂凑瘴覀円郧暗臉?gòu)想,在執(zhí)行后兩條 SQL 時(shí) 應(yīng)該拋出 ‘Duplicate key' 的異常的。

后來(lái)查了一下,才發(fā)現(xiàn)其實(shí) MySQL 官方文檔上已經(jīng)明確說(shuō)了這一點(diǎn), 唯一性索引是允許多個(gè) 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.

從下表中也可以看出來(lái)不管是采用什么類型的存儲(chǔ)引擎,在建立 unique key 的時(shí)候都是允許多個(gè) NULL 存在的。。。。

細(xì)想想,其實(shí)也蠻合理,畢竟在 MySQL 中認(rèn)為 NULL 代表著“未知”。 在 SQL 中,任何值與 NULL 的比較返回值都是 NULL 而不是 TRUE, 就算 NULL 與 NULL 的比較也是返回 NULL。

所以只能 fix 了。。。解決辦法也蠻簡(jiǎn)單粗暴的,直接把線上數(shù)據(jù)刷了一遍,將“1970-01-01 08:00:00”作為默認(rèn)值,然后把那列改為不允許為 NULL 的了,咳咳。

MySQL 官網(wǎng)上也有蠻多人討論過(guò)這個(gè)問(wèn)題,一部分人認(rèn)為這是 MySQL 的 bug, 另一部分則認(rèn)為是一個(gè) feature,附上鏈接。

MySQL Bugs: #8173: unique index allows duplicates with null values

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)腳本之家的支持。

相關(guān)文章

  • Mysql GROUP BY查詢每組某值最大的一條數(shù)據(jù)

    Mysql GROUP BY查詢每組某值最大的一條數(shù)據(jù)

    這篇文章主要介紹了Mysql GROUP BY查詢每組某值最大的一條數(shù)據(jù)問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-08-08
  • MySQL數(shù)據(jù)庫(kù)的多表操作

    MySQL數(shù)據(jù)庫(kù)的多表操作

    這篇文章主要介紹了MySQL數(shù)據(jù)庫(kù)的多表操作,文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,感興趣的小伙伴可以參考一下,希望對(duì)你的學(xué)習(xí)有所幫助
    2022-08-08
  • mysql更新一個(gè)表里的字段等于另一個(gè)表某字段的值實(shí)例

    mysql更新一個(gè)表里的字段等于另一個(gè)表某字段的值實(shí)例

    下面小編就為大家?guī)?lái)一篇mysql更新一個(gè)表里的字段等于另一個(gè)表某字段的值實(shí)例。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-03-03
  • 一文詳解MySQL—Join的使用優(yōu)化

    一文詳解MySQL—Join的使用優(yōu)化

    JOIN是一種非常常見(jiàn)的操作,用于將兩個(gè)或多個(gè)表中的數(shù)據(jù)合并到一個(gè)結(jié)果集中。MySQL支持多種JOIN類型,本文通過(guò)代碼示例詳細(xì)介紹了Join的使用優(yōu)化,有需要的小伙伴可以參考閱讀
    2023-04-04
  • 通過(guò)緩存+SQL修改優(yōu)雅地優(yōu)化慢查詢

    通過(guò)緩存+SQL修改優(yōu)雅地優(yōu)化慢查詢

    本文通過(guò)介紹緩存的基本原理和SQL語(yǔ)句的優(yōu)化手段,以及實(shí)際案例的分析,為讀者提供了一種簡(jiǎn)單而有效的優(yōu)化思路。讀者可以通過(guò)本文了解到如何在不修改程序代碼的情況下,通過(guò)巧妙地運(yùn)用緩存和SQL優(yōu)化技巧,提高程序的性能和響應(yīng)速度。
    2023-04-04
  • 詳解如何通過(guò)Mysql的二進(jìn)制日志恢復(fù)數(shù)據(jù)庫(kù)數(shù)據(jù)

    詳解如何通過(guò)Mysql的二進(jìn)制日志恢復(fù)數(shù)據(jù)庫(kù)數(shù)據(jù)

    本篇文章主要介紹了詳解如何通過(guò)Mysql的二進(jìn)制日志恢復(fù)數(shù)據(jù)庫(kù)數(shù)據(jù),具有一定的參考價(jià)值,有興趣的可以了解一下。
    2017-04-04
  • 如何批量生成MySQL不重復(fù)手機(jī)號(hào)大表實(shí)例代碼

    如何批量生成MySQL不重復(fù)手機(jī)號(hào)大表實(shí)例代碼

    這篇文章主要給大家介紹了關(guān)于如何批量生成MySQL不重復(fù)手機(jī)號(hào)大表的相關(guān)資料,,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2018-11-11
  • 基于mysql 默認(rèn)排序規(guī)則的坑

    基于mysql 默認(rèn)排序規(guī)則的坑

    這篇文章主要介紹了解決mysql 默認(rèn)排序規(guī)則的坑,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看不看
    2021-02-02
  • MySQL主從同步延遲原因與解決方案

    MySQL主從同步延遲原因與解決方案

    本文主要介紹了MySQL主從同步延遲原因與解決方案,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-11-11
  • MySQL按照漢字的拼音排序簡(jiǎn)單實(shí)例

    MySQL按照漢字的拼音排序簡(jiǎn)單實(shí)例

    下面小編就為大家?guī)?lái)一篇MySQL按照漢字的拼音排序簡(jiǎn)單實(shí)例。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-01-01

最新評(píng)論