您好,登錄后才能下訂單哦!
這篇文章主要介紹了NULL和唯一約束UNIQUE的對應(yīng)關(guān)系是什么,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
NULL和唯一約束UNIQUE的對應(yīng)關(guān)系
在數(shù)據(jù)庫中,NULL表示列值為空。唯一約束UNIQUE規(guī)定指定列的值必須是唯一的,值和值之間都不能相同。這個時候,就出現(xiàn)一個問題,NULL和NULL算是相同,還是不同。由于SQL語法沒有明確規(guī)定,所以各個數(shù)據(jù)庫廠商的處理方式不同。
(1)PostgreSQL和Oracle認(rèn)為NULL表示沒有指定數(shù)據(jù),所以數(shù)據(jù)有多種可能,所以UNIQUE約束列中允許存在任意個NULL。
(2)Informix和SQL Server認(rèn)為NULL就表示空,是一種唯一的狀態(tài)。所以UNIQUE約束列中只能有一個NULL。
(3)DB2、SQLAnyWhere和InterBase認(rèn)為NULL存在不確定性,無法比較,所以UNIQUE約束列中不允許有NULL。
而SQLite遵循了PostgreSQL和Oracle的策略,允許UNIQUE約束列中有任意個NULL。
感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“NULL和唯一約束UNIQUE的對應(yīng)關(guān)系是什么”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,更多相關(guān)知識等著你來學(xué)習(xí)!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。