검사 제약 조건의 하위 쿼리: 대체 솔루션 탐색
검사 제약 조건은 열에 삽입되거나 업데이트될 수 있는 값을 제한하여 데이터 무결성을 강화합니다. . 하위 쿼리는 복잡한 조건을 지정하는 강력한 방법을 제공하지만 일반적으로 SQL Server의 검사 제약 조건 내에서는 허용되지 않습니다. 이러한 제한으로 인해 다른 테이블에 대해 데이터 무결성을 적용해야 하는 문제가 발생합니다.
한 가지 해결책은 트리거를 사용하는 것입니다. 그러나 트리거는 추가적인 오버헤드와 성능에 영향을 미칠 수 있습니다. 대안으로 스칼라 함수를 활용하여 하위 쿼리를 캡슐화하고 검사 제약 조건에 사용할 수 있는 부울 값을 반환할 수 있습니다.
이 접근 방식을 설명하려면 열의 값(MyField )가 다른 테이블(Table2)에 존재합니다. 이 확인을 수행하는 함수를 생성하는 방법은 다음과 같습니다.
CREATE FUNCTION myFunction(@Field DATATYPE(?)) RETURNS VARCHAR(5) AS BEGIN IF EXISTS (SELECT * FROM Table2 WHERE MYFIELD = @field) return 'True' return 'False' END
이 함수는 매개변수를 받아들이고 Table2에서 해당 매개변수의 존재를 확인하고 부울 값을 반환합니다. 그런 다음 이 기능을 검사 제약 조건에 통합할 수 있습니다.
ALTER TABLE Table1 WITH CHECK ADD CONSTRAINT CK_Code CHECK (myFunction(MYFIELD) = 'True')
스칼라 함수를 활용하면 검사 제약 조건 내에서 원하는 하위 쿼리 유효성 검사를 효과적으로 수행하여 성능 저하나 트리거에 의존하지 않고 데이터 무결성을 보장할 수 있습니다.
위 내용은 SQL Server 검사 제약 조건에서 하위 쿼리를 효과적으로 사용하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!