六月婷婷综合激情-六月婷婷综合-六月婷婷在线观看-六月婷婷在线-亚洲黄色在线网站-亚洲黄色在线观看网站

明輝手游網(wǎng)中心:是一個免費提供流行視頻軟件教程、在線學(xué)習(xí)分享的學(xué)習(xí)平臺!

MySQL中有關(guān)NULL詳細說明

[摘要]這里記錄的是很久之前的一個 bug 了,主要給大家介紹了關(guān)于MySQL中唯一性約束與NULL的相關(guān)資料,文中介紹的非常詳細,對大家具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起看看吧。前言之前做的一個需求,簡化描述下就是接受其他組的 MQ 的消息,然后在數(shù)據(jù)庫里插入一條記錄。為了防止他們重復(fù)發(fā)消息...
這里記錄的是很久之前的一個 bug 了,主要給大家介紹了關(guān)于MySQL中唯一性約束與NULL的相關(guān)資料,文中介紹的非常詳細,對大家具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起看看吧。

前言

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


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

藍后。。。就出問題了。加了 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ù)庫中會有多條一樣的記錄。可按照我們以前的構(gòu)想,在執(zhí)行后兩條 SQL 時 應(yīng)該拋出 ‘Duplicate key' 的異常的。

后來查了一下,才發(fā)現(xiàn)其實 MySQL 官方文檔上已經(jīng)明確說了這一點, 唯一性索引是允許多個 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中有關(guān)NULL詳解

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

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

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

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

以上就是MySQL中有關(guān)NULL詳解的詳細內(nèi)容,更多請關(guān)注php中文網(wǎng)其它相關(guān)文章!


學(xué)習(xí)教程快速掌握從入門到精通的SQL知識。




主站蜘蛛池模板: 亚洲成av人影院 | 特级黄一级播放 | 在线h观看 | 日韩 欧美 亚洲国产 | 欧美一区二区三区播放 | 青青青青手机在线视频观看国产 | 亚洲福利视频网址 | 欧美一级视频在线观看欧美 | 社区天堂 | 婷婷中文字幕 | 天天综合网天天综合色不卡 | 啪啪网站视频 | 伊人精品视频在线观看 | 日日噜噜夜夜狠狠久久aⅴ 日日噜噜夜夜狠狠扒开双腿 | 特级黄视频 | 日本精品一区 | 私色综合网 | 日本天堂影院在线播放 | 中文字幕在线视频第一页 | 午夜免费片 | 四虎国产精品视频免费看 | 日韩a视频在线观看 | 思思99re66在线精品免费观看 | 天天色综合4| 日韩h| 日本三级视频 | 一二三四在线观看高清在线观看一 | 在线国产日韩 | 色综合成人丁香 | 五月婷婷六月激情 | 天天操天天透 | 日韩专区亚洲精品欧美专区 | 一级做a爰在线就看 | 亚洲精品老司机在线观看 | 亚洲三级网站 | 亚洲小视频在线观看 | 日韩视频在线观看中字 | 色综合久久中文字幕网 | 天天看天天摸天天操 | 一二三四手机在线观看视频播放 | 伊人网在线免费视频 |