好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > MySQL中的唯一性約束與NULL詳解

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

熱門標簽:長安區違法建房地圖標注 南宋地圖標注黃河華山 手機用地圖標注工具 智能電銷機器人靠譜么 地圖標注培訓 電銷機器人說明書 安國在哪里辦理400電話 昆明智能外呼系統中心 電銷機器人公眾號推送

前言

之前做的一個需求,簡化描述下就是接受其他組的 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中的唯一性約束與NULL詳解》,本文關鍵詞  MySQL,中的,唯一性,約束,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《MySQL中的唯一性約束與NULL詳解》相關的同類信息!
  • 本頁收集關于MySQL中的唯一性約束與NULL詳解的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 日本精品99| 放荡小婬妇h嗯啊~轻点总裁| 羞羞18??拔萝卜免费观看| 女主从小被肉调教到大h文np| 国精品无人区码一二三四| 日韩毛片免费线上观看| 机机对机机免费30分钟app| 智取小婷动漫免费| 美人被强行糟蹋np各种play| 操操操日日日| 香港A片毛片免费观看蜜挑成熟时| 啊好舒服好爽| 欧美做爰BBB性BBBBB8| 国产真人做爰毛片视频直播| 欧美黄网站免费观看| 日韩三级中文字幕| 女教师屈辱沦陷调教哀求小说| 极品粉嫩国产尤物在线观看| 国产高清一级视频在线观看| 高清国产一区| 日韩亚洲制服丝袜中文字幕| 日你逼| 一代女皇艳史A片| 在线观看国产高清免费不卡黄| 霍水儿小说| 国产午夜精品久久69久久嫩草| 无码专区—VA亚洲V天堂| 翘臀趴着h| 国产精品久久久久精品三级涩| 把女人爽到特黄AAA片| 亚洲欧美午夜精品无码站长工具| **性色生活片毛片| 人妻熟妇女欲乱系列| 尻逼美女| 国产成人永久免费视频| 爆乳上司JULIA中文字幕99| 921高清国产区| 宝贝你湿了| 久久嫩草国产成人一区| 国产免费又粗又长又猛桃花视频| 直男癌进入言情小说后|