GUIDを入力する列に一意の制約を設定します。ただし、私のデータにはこの列のnull値が含まれています。複数のnull値を許可する制約を作成するにはどうすればよいですか?
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);
最後のステートメントは次のメッセージで失敗します。
UNIQUE KEY制約「UQ_People_LibraryCardId」の違反。オブジェクト 'dbo.People'に重複するキーを挿入することはできません。
NULL
実際のデータの一意性を確認しながら、スキーマや一意性制約を変更して複数の値を許可するにはどうすればよいですか?
null
が価値ではなく価値の欠如であると考えるとき。標準SQLに従って、null
と等しいとは見なされませんnull
。では、なぜ複数null
が一意性違反である必要があるのでしょうか。