91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

MySQL中唯一性約束與NULL的示例分析

發布時間:2021-06-04 11:59:52 來源:億速云 閱讀:236 作者:小新 欄目:MySQL數據庫

這篇文章給大家分享的是有關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的示例分析

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

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

MySQL 官網上也有蠻多人討論過這個問題,一部分人認為這是 MySQL 的 bug, 另一部分則認為是一個 feature。

感謝各位的閱讀!關于“MySQL中唯一性約束與NULL的示例分析”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

惠来县| 汤原县| 乌拉特后旗| 平顶山市| 鄯善县| 会昌县| 团风县| 垣曲县| 广宗县| 织金县| 阳春市| 陈巴尔虎旗| 文登市| 特克斯县| 墨玉县| 淮安市| 渭源县| 临江市| 金川县| 深泽县| 邵武市| 华蓥市| 巴中市| 巴彦淖尔市| 池州市| 会昌县| 丹江口市| 汝城县| 隆安县| 开封县| 嘉善县| 海伦市| 顺义区| 稻城县| 卫辉市| 清徐县| 南投市| 雷波县| 石家庄市| 关岭| 漯河市|