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
이 고유성 위반이어야합니까?