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