함수를 사용하여 검사 제약 조건 정의
여러 테이블로 작업할 때 테이블 간의 데이터 무결성을 보장해야 할 수 있습니다. 이를 달성하는 한 가지 방법은 검사 제약 조건을 사용하는 것입니다. 그러나 검사 제약 조건이 다른 테이블과 관련되어 효과적으로 데이터를 상호 참조할 수 있습니까?
문제점과 해결 방법
두 개의 테이블이 있는 시나리오를 생각해 보세요. 열이 있는 ProjectTimeSpan StartDate 및 EndDate와 StartDate 및 EndDate 열도 포함하는 SubProjectTimeSpan. SubProjectTimeSpan 날짜가 ProjectTimeSpan 날짜를 벗어나는 것을 방지하는 확인 제약 조건을 어떻게 적용할 수 있나요?
답은 확인 제약 조건 정의 내의 기능을 활용하는 데 있습니다. ProjectTimeSpan에서 관련 데이터를 검색하는 함수를 생성하면 이에 대해 SubProjectTimeSpan 값의 유효성을 검사할 수 있습니다.
예
다음은 함수를 사용하는 검사 제약 조건의 예입니다. :
alter table YourTable add constraint chk_CheckFunction check (dbo.CheckFunction() = 1)
이 예에서는 dbo.CheckFunction() 함수가 다음을 담당합니다. ProjectTimeSpan에 대해 SubProjectTimeSpan 값을 확인합니다. 함수 정의는 다음과 같습니다.
create function dbo.CheckFunction() returns int as begin return (select 1 where ...) -- Your validation logic goes here end
이 함수를 사용하면 ProjectTimeSpan의 데이터를 상호 참조하고 SubProjectTimeSpan 테이블 데이터의 무결성을 확인할 수 있습니다.
위 내용은 함수를 사용하여 테이블 간 제약 조건 상호 참조 데이터를 확인할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!