SQL Server 2005: 열 하위 집합에 대한 조건부 고유성 구현
SQL Server 2005에서는 특정 조건에서만 적용되는 고유한 제약 조건을 만드는 것이 어렵습니다. 트리거는 솔루션을 제공하지만 성능에 영향을 미칠 수 있습니다. 보다 효율적인 접근 방식은 필터링된 인덱스를 활용하는 것입니다.
필터링된 인덱스: 조건부 제약 조건에 대한 동적 솔루션
필터링된 인덱스를 사용하면 특정 데이터 하위 집합의 인덱싱이 가능하며 필터 조건자를 통해 조건부 제약 조건을 구현하기 위한 강력한 메커니즘을 제공합니다.
필터링된 인덱스를 사용하여 조건부 고유 제약 조건 생성
다음 T-SQL 문은 필터를 사용하여 고유 인덱스를 생성하는 방법을 보여줍니다.
<code class="language-sql">CREATE UNIQUE INDEX MyIndex ON MyTable (ID) WHERE RecordStatus = 1;</code>
이렇게 하면 ID
열에 고유 제약 조건이 생성되지만 RecordStatus
이 1인 경우에만 해당됩니다. 이 조건부 고유성을 위반하려고 하면 오류가 발생합니다.
오류 메시지 예:
ID
이 1일 때 중복된 RecordStatus
값을 삽입하려고 하면 다음과 같은 결과가 발생합니다.
<code>Msg 2601, Level 14, State 1, Line 13 Cannot insert duplicate key row in object 'dbo.MyTable' with unique index 'MyIndex'. The duplicate key value is (9999).</code>
요약
필터링된 인덱스는 SQL Server 2005에서 조건부 고유 제약 조건을 설정하는 효율적이고 우아한 방법을 제공하여 트리거 기반 솔루션과 관련된 성능 오버헤드를 방지합니다. 필터 조건자를 사용하면 특정 데이터 하위 집합 내 고유성을 동적으로 제어할 수 있습니다.
위 내용은 SQL Server 2005에서 조건부 고유 제약 조건을 어떻게 구현할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!