>데이터 베이스 >MySQL 튜토리얼 >단일 데이터베이스 열이 여러 외래 키를 참조할 수 있습니까?

단일 데이터베이스 열이 여러 외래 키를 참조할 수 있습니까?

Linda Hamilton
Linda Hamilton원래의
2024-12-25 10:17:19995검색

Can a Single Database Column Reference Multiple Foreign Keys?

데이터베이스 열 내 다중 참조 외래 키

데이터베이스 설계에서 외래 키 제약 조건은 참조 무결성을 유지하고 보장하는 데 중요한 역할을 합니다. 데이터 정확성. 일반적으로 외래 키 열은 다른 테이블의 기본 키 열을 참조하여 레코드 간에 일대다 또는 다대다 관계를 설정합니다. 그러나 질문이 생깁니다. 여러 테이블에 대한 외래 키 역할을 하는 단일 열을 정의할 수 있습니까?

열이 여러 외래 키를 참조할 수 있습니까?

답변 아닙니다. 데이터베이스 원칙에 따르면 단일 열이 여러 외래 키를 동시에 참조하는 것은 허용되지 않습니다. 이 제한은 모든 주요 관계형 데이터베이스 관리 시스템(RDBMS)에 의해 시행됩니다.

설명

외래 키의 주요 목적은 데이터베이스의 레코드 간에 직접 링크를 설정하는 것입니다. 다른 테이블. 각 외래 키 값은 참조된 테이블의 행을 고유하게 식별해야 합니다. 단일 열에서 여러 외래 키를 참조하려고 하면 이 기본 원칙을 위반하게 됩니다.

다중 참조 외래 키에 대한 대안

테이블이 여러 개인 경우 고려해야 할 대체 접근 방식이 있습니다.

  1. 참여 테이블: 관련 테이블의 기본 키를 포함하는 별도의 테이블을 생성합니다. 이 조인 테이블은 여러 테이블의 레코드를 연결하는 중개자 역할을 합니다.
  2. 복합 키: 여러 열로 구성된 기본 키를 정의합니다. 이를 통해 여러 열을 동시에 참조하는 외래 키 제약 조건을 생성할 수 있습니다.

복합 키를 사용한 예

질문에 제공된 예를 고려하세요.

CREATE TABLE pdf_created (
    `id` INT(10) UNSIGNED NOT NULL UNIQUE AUTO_INCREMENT,
    `pdf_id` INT(10) NOT NULL,
    `item_type` INT(3) UNSIGNED NOT NULL,
    `item_id` INT(10) UNSIGNED NOT NULL,
    PRIMARY KEY (`id`, `item_type`, `item_id`)
);

CREATE TABLE `header` (
    `id` INT(10) UNSIGNED NOT NULL UNIQUE AUTO_INCREMENT,
    `title` VARCHAR(255)
);

CREATE TABLE `service` (
    `id` INT(10) UNSIGNED NOT NULL UNIQUE AUTO_INCREMENT,
    `desc` VARCHAR(65535) NOT NULL
);

CREATE TABLE `product` (
    `id` INT(10) UNSIGNED NOT NULL UNIQUE AUTO_INCREMENT,
    `desc` VARCHAR(65535) NOT NULL
);

이 스키마에서 pdf_created 테이블의 item_id 열은 제품 테이블과 서비스 테이블의 ID 열. 이는 id 및 item_type 열을 모두 사용하여 pdf_created 테이블에 복합 기본 키를 정의함으로써 달성됩니다.

결론

단일 열을 갖는 것이 직접적으로 가능하지는 않습니다. 관계형 데이터베이스에서 여러 외래 키를 참조하는 경우 조인 테이블이나 복합 키와 같은 대체 접근 방식을 사용하여 레코드 간에 필요한 관계를 설정할 수 있습니다.

위 내용은 단일 데이터베이스 열이 여러 외래 키를 참조할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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