>데이터 베이스 >MySQL 튜토리얼 >접합 테이블을 사용하여 PostgreSQL에서 다대다 관계를 구현하는 방법은 무엇입니까?

접합 테이블을 사용하여 PostgreSQL에서 다대다 관계를 구현하는 방법은 무엇입니까?

DDD
DDD원래의
2025-01-22 15:02:11140검색

How to Implement Many-to-Many Relationships in PostgreSQL Using Junction Tables?

조인 테이블을 사용하여 PostgreSQL에서 다대다 관계 구현

다대다 관계의 이해

다대다 관계에서는 단일 엔터티가 여러 다른 엔터티와 관련될 수 있으며 그 반대의 경우도 마찬가지입니다. 이를 데이터베이스에서 표현하기 위해 일반적으로 "조인 테이블"이라는 별도의 테이블이 사용됩니다.

PostgreSQL에서 테이블 구조 생성

PostgreSQL에서 다대다 관계를 생성하려면 먼저 두 개의 기본 테이블을 정의한 다음 조인 테이블을 생성해야 합니다.

<code class="language-sql">CREATE TABLE product (
  product_id serial PRIMARY KEY  -- 隐式主键约束
, product    text NOT NULL
, price      numeric NOT NULL DEFAULT 0
);

CREATE TABLE bill (
  bill_id  serial PRIMARY KEY
, bill     text NOT NULL
, billdate date NOT NULL DEFAULT CURRENT_DATE
);

CREATE TABLE bill_product (
  bill_id    int REFERENCES bill (bill_id) ON UPDATE CASCADE ON DELETE CASCADE
, product_id int REFERENCES product (product_id) ON UPDATE CASCADE
, amount     numeric NOT NULL DEFAULT 1
, CONSTRAINT bill_product_pkey PRIMARY KEY (bill_id, product_id)  -- 显式主键
);</code>

테이블 구조의 주요 특징

  • 제품:은 이름과 가격이 포함된 단일 제품을 나타냅니다.
  • 청구서:는 설명과 날짜가 포함된 단일 청구서를 나타냅니다.
  • Bill_Product: 다대다 관계를 위한 연결 테이블을 만듭니다. 여기에는 Product 및 Bill 테이블에 대한 두 개의 외래 키와 각 조합에 대한 금액 열이 포함되어 있습니다.

메모

  • 대리 기본 키: 일련 열을 Product 및 Bill 테이블의 대리 기본 키로 정의했습니다. 이는 시스템에서 자동으로 생성된 고유한 정수 값으로, 쿼리에서 테이블 조인을 더욱 효율적으로 만듭니다.
  • 명명 규칙: 테이블에는 단수 명사를 사용하고 열 이름에는 소문자를 사용하는 일관된 명명 규칙을 따릅니다.
  • 데이터 유형: 정확성을 보장하기 위해 숫자 유형으로 가격, 날짜 유형으로 청구일과 같은 적절한 데이터 유형을 선택했습니다.
  • 외래 키: 외래 키는 변경 사항이나 삭제를 자동으로 전파하기 위해 ON UPDATE CASCADE 및 ON DELETE CASCADE로 정의되었습니다.
  • NOT NULL 제약 조건: 데이터 무결성을 강화하기 위해 모든 열을 NOT NULL로 정의했습니다.
  • 색인:은 Bill_Product 테이블의 기본 키에 대한 색인을 자동으로 생성하여 쿼리 속도를 높입니다.

위 내용은 접합 테이블을 사용하여 PostgreSQL에서 다대다 관계를 구현하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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