亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

如何創建允許空的唯一約束?

如何創建允許空的唯一約束?

湖上湖 2019-07-05 10:03:09
如何創建允許空的唯一約束?我希望在一個列上有一個唯一的約束,我將用GUID填充該列。但是,我的數據包含此列的空值。如何創建允許多個空值的約束?這是一個示例場景..考慮一下這個模式:CREATE TABLE People (   Id INT CONSTRAINT PK_MyTable PRIMARY KEY IDENTITY,   Name NVARCHAR(250) NOT NULL,   LibraryCardId UNIQUEIDENTIFIER NULL,   CONSTRAINT UQ_People_LibraryCardId UNIQUE (LibraryCardId))然后看看這段代碼,看看我想要達到的目標:-- This works fine:INSERT INTO People (Name, LibraryCardId)   VALUES ('John Doe', 'AAAAAAAA-AAAA-AAAA-AAAA-AAAAAAAAAAAA');-- This also works fine, obviously:  INSERT INTO People (Name, LibraryCardId) VALUES ('Marie Doe', 'BBBBBBBB-BBBB-BBBB-BBBB-BBBBBBBBBBBB');  -- This would *correctly* fail:  --INSERT INTO People (Name, LibraryCardId) --VALUES ('John Doe the Second', 'AAAAAAAA-AAAA-AAAA-AAAA-AAAAAAAAAAAA');  -- This works fine this one first time:INSERT INTO People (Name, LibraryCardId) VALUES ('Richard Roe', NULL);  -- THE PROBLEM: This fails even though I'd like to be able to do this:INSERT INTO People (Name, LibraryCardId) VALUES ('Marcus Roe', NULL);最后一條語句失敗,其中包含一條消息:違反唯一密鑰約束‘UQ_People_Library aryCardId’。無法在對象‘dbo.People’中插入重復鍵。如何更改架構和/或唯一性約束,使其允許多個NULL值,同時仍然檢查實際數據的唯一性?
查看完整描述

3 回答

?
RISEBY

TA貢獻1856條經驗 獲得超5個贊

SQLServer 2008+

屬性創建接受多個NULL的唯一索引。WHERE條款。見回答如下.

SQLServer 2008之前

您不能創建唯一的約束并允許NULL。您需要設置一個默認值newid()。

在創建唯一約束之前,將現有值更新為newid(),其中NULL。


查看完整回答
反對 回復 2019-07-05
?
holdtom

TA貢獻1805條經驗 獲得超10個贊

您要尋找的確實是ANSI標準SQL:92、SQL:1999和SQL:2003的一部分,即唯一的約束必須不允許重復的非空值,而是接受多個空值。

然而,在Microsoft的SQLServer世界中,只允許一個NULL,但不允許多個NULL.

在……里面SQLServer 2008,可以根據排除NULL的謂詞定義唯一篩選索引:

CREATE UNIQUE NONCLUSTERED INDEX idx_yourcolumn_notnullON YourTable(yourcolumn)WHERE yourcolumn IS NOT NULL;

在早期版本中,可以使用帶有NOTNULL謂詞的視圖來強制執行約束。


查看完整回答
反對 回復 2019-07-05
  • 3 回答
  • 0 關注
  • 802 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號