MySQL 唯一約束:空值
在 MySQL 中,強制執行唯一限制以確保指定列中值的唯一性。但是,在處理電子郵件地址時,常見的情況是使用空值來表示可選或未提供的地址。這就提出了一個問題:
MySQL 可以允許在具有唯一約束的欄位中存在多個空值嗎?
答案:
是的,MySQL 允許在具有唯一約束的欄位中存在多個空值。此行為與某些其他資料庫系統不同。
範例:
下列 SQL 語句建立一個名為 table1 的資料表,其中的整數列 x被定義為唯一並允許空值:
CREATE TABLE table1 (x INT NULL UNIQUE);
將重複的空值插入此表不會引發錯誤:
INSERT table1 VALUES (1); INSERT table1 VALUES (1); -- Duplicate entry '1' for key 'x' INSERT table1 VALUES (NULL); INSERT table1 VALUES (NULL);
執行查詢檢索table1 中的所有記錄將產生以下結果:
SELECT * FROM table1;
x |
---|
NULL |
NULL |
1 |
注意: 此行為是特定的到MySQL。其他資料庫系統(例如 SQL Server 2005 及更早版本)會限制具有唯一約束的欄位中允許出現單一空值。
以上是MySQL的唯一限制可以處理多個NULL值嗎?的詳細內容。更多資訊請關注PHP中文網其他相關文章!