> 데이터 베이스 > MySQL 튜토리얼 > DELETE ON CASCADE를 사용하는 MySQL 외래 키 제약 조건이 어떻게 데이터 불일치를 방지할 수 있습니까?

DELETE ON CASCADE를 사용하는 MySQL 외래 키 제약 조건이 어떻게 데이터 불일치를 방지할 수 있습니까?

Mary-Kate Olsen
풀어 주다: 2024-12-13 07:15:10
원래의
294명이 탐색했습니다.

How Can MySQL Foreign Key Constraints with DELETE ON CASCADE Prevent Data Inconsistency?

데이터 불일치를 방지하기 위해 MySQL 외래 키 제약 조건 사용

데이터 무결성을 유지하고 고아 레코드를 방지하려면 외래 키 제약 조건을 구현하는 것이 중요합니다. 이는 InnoDB 테이블을 활용할 때 특히 중요합니다. 외래 키는 테이블 간의 관계를 설정하여 상위 레코드가 삭제되면 해당 하위 레코드도 자동으로 삭제되도록 합니다.

DELETE ON CASCADE 이해

DELETE ON CASCADE는 상위 레코드가 삭제되면 하위 레코드도 자동으로 삭제하는 외래 키 제약 조건입니다. 이는 유효한 상위 레코드 없이 하위 레코드가 존재하는 데이터 분리를 방지합니다.

외래 키 제약 조건 설정 및 DELETE ON CASCADE

DELETE ON으로 외래 키 제약 조건을 설정하려면 CASCADE, 다음 단계를 따르세요.

  1. 상위 항목을 만들고 하위 테이블: 적절한 열과 기본 키를 사용하여 상위(예: 카테고리) 및 ​​하위(예: 제품) 테이블을 모두 정의합니다.
  2. 피벗 테이블 만들기: 피벗 디자인 상위와 하위 간의 다대다 관계를 설정하기 위한 테이블(예: 카테고리_제품)
  3. 외래 키 제약 조건 정의: 피벗 테이블에서 상위 및 하위 기본 키를 참조하는 외래 키 제약 조건을 만듭니다. 외래 키 정의에 "ON DELETE CASCADE" 절을 추가합니다.

예:

문제 설명에 언급된 예제 테이블을 고려하세요.

categories
- id (INT)
- name (VARCHAR 255)

products
- id
- name
- price

categories_products
- categories_id
- products_id
로그인 후 복사

적절한 외래 키 제약 조건을 설정하려면 다음과 같이 테이블을 생성합니다. 다음:

CREATE TABLE categories (
    id int unsigned not null primary key,
    name VARCHAR(255) default null
)Engine=InnoDB;

CREATE TABLE products (
    id int unsigned not null primary key,
    name VARCHAR(255) default null
)Engine=InnoDB;

CREATE TABLE categories_products (
    category_id int unsigned not null,
    product_id int unsigned not null,
    PRIMARY KEY (category_id, product_id),
    KEY pkey (product_id),
    FOREIGN KEY (category_id) REFERENCES categories (id)
       ON DELETE CASCADE
       ON UPDATE CASCADE,
    FOREIGN KEY (product_id) REFERENCES products (id)
       ON DELETE CASCADE
       ON UPDATE CASCADE
)Engine=InnoDB;
로그인 후 복사

이 설정을 사용하면 카테고리를 삭제하면 카테고리_제품의 해당 레코드만 삭제되어 제품 테이블의 무결성이 유지됩니다. 그러나 제품을 삭제해도 카테고리 테이블에는 영향을 미치지 않습니다.

DELETE ON CASCADE를 사용하여 외래 키 제약 조건을 신중하게 구현하면 데이터 무결성을 유지하고 데이터 손상을 방지하여 데이터베이스에 레코드 간의 올바른 관계가 반영되도록 할 수 있습니다.

위 내용은 DELETE ON CASCADE를 사용하는 MySQL 외래 키 제약 조건이 어떻게 데이터 불일치를 방지할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿