>데이터 베이스 >MySQL 튜토리얼 >기본 키가 아닌 열을 참조하는 외래 키 제약 조건을 어떻게 만들 수 있나요?

기본 키가 아닌 열을 참조하는 외래 키 제약 조건을 어떻게 만들 수 있나요?

Barbara Streisand
Barbara Streisand원래의
2025-01-15 09:27:42444검색

How Can I Create a Foreign Key Constraint Referencing a Non-Primary Key Column?

외래 키를 사용하여 기본 키가 아닌 열의 참조 무결성 유지

데이터베이스 시스템에서 외래 키는 테이블 간의 관계를 설정하고 참조 무결성을 강화하는 데 사용됩니다. 일반적으로 외래 키는 종속 테이블의 데이터 일관성을 보장하기 위해 다른 테이블의 기본 키를 참조합니다. 그러나 경우에 따라 기본 키가 아닌 열을 가리키는 외래 키를 생성해야 할 수도 있습니다.

한 테이블(table2)이 다른 테이블(table1)과 참조 무결성을 유지해야 하지만 table1에서 참조되는 열이 기본 키가 아닌 질문에 설명된 시나리오를 고려해 보겠습니다. 제공된 샘플 SQL 코드는 생성하려는 테이블 및 외래 키 정의를 보여줍니다.

<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>

문제는 table1의 AnotherID 열이 기본 키가 아니라는 것입니다. 대부분의 데이터베이스 시스템에서 외래 키는 기본 키나 고유 제약 조건이 있는 열만 참조할 수 있습니다.

이 문제를 해결하려면 참조된 열(table1의 AnotherID)에 고유 제약 조건이 정의되어 있는지 확인해야 합니다. 고유 제약 조건은 행별로 적용되어 열의 값이 테이블의 모든 행에서 고유하도록 보장합니다.

table1의 AnotherID에 고유 제약 조건을 추가하면 외래 키 참조의 후보가 됩니다. 다음 수정된 SQL 코드는 이 수정 사항을 보여줍니다.

<code class="language-sql">ALTER TABLE table1
ADD UNIQUE (AnotherID)</code>

이제 table2에서 외래 키 제약 조건을 성공적으로 정의하여 두 테이블 간의 참조 무결성을 적용할 수 있습니다.

<code class="language-sql">ALTER TABLE table2
ADD CONSTRAINT FK_Table2_Table1 FOREIGN KEY (AnotherID) REFERENCES table1 (AnotherID)</code>

그러나 원래 질문에 대한 답변에서 알 수 있듯이 일반적으로 기본 키를 후보 키로 사용하는 것이 좋습니다. 기본 키는 자동으로 고유한 것으로 정의되므로 추가 제약 조건이 필요하지 않고 외래 키 정의가 단순화됩니다.

위 내용은 기본 키가 아닌 열을 참조하는 외래 키 제약 조건을 어떻게 만들 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.