외래 키 제약 조건에서 기본 키가 아닌 참조
외래 키를 통해 테이블을 연결할 때 참조 무결성을 유지하는 것은 일반적인 요구 사항입니다. 그러나 이러한 상황은 외래 키가 참조하는 테이블에 참조된 열에 해당하는 기본 키가 없는 경우 발생합니다.
문제 설명:
다음 데이터베이스 스키마를 고려하십시오.
<code class="language-sql">CREATE TABLE table1 ( ID INT NOT NULL IDENTITY(1,1) PRIMARY KEY, AnotherID INT NOT NULL, SomeData VARCHAR(100) NOT NULL ); CREATE TABLE table2 ( ID INT NOT NULL IDENTITY(1,1) PRIMARY KEY, AnotherID INT NOT NULL, MoreData VARCHAR(30) NOT NULL, CONSTRAINT fk_table2_table1 FOREIGN KEY (AnotherID) REFERENCES table1 (AnotherID) );</code>
여기서 목표는 table2.AnotherID와 table1.AnotherID 사이에 외래 키 제약 조건을 적용하는 것입니다. 그러나 ID는 table1의 기본 키이고 AnotherID는 아닙니다.
해결책:
기본 키가 아닌 키를 참조하는 외래 키 제약 조건을 만들려면 참조된 열에 고유 제약 조건이 적용되어 있어야 합니다. Microsoft 온라인 도서에 따르면:
"FOREIGN KEY 제약 조건은 다른 테이블의 PRIMARY KEY 제약 조건에만 연결될 필요는 없습니다. 또한 다른 테이블의 UNIQUE 제약 조건을 참조하는 열로 정의할 수도 있습니다.
따라서 지정된 스키마에서 table1의 AnotherID에 고유 제약 조건을 적용하면 외래 키 제약 조건을 생성할 수 있습니다.
<code class="language-sql">ALTER TABLE table1 ADD CONSTRAINT UQ_AnotherID UNIQUE (AnotherID);</code>
그러나 대체 기본 키 후보가 존재하는 경우 이를 사용하는 것이 더 적절한 접근 방식인 경우가 많다는 점에 유의하는 것이 중요합니다.
위 내용은 기본 키가 아닌 열을 참조하는 외래 키 제약 조건을 만드는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!