>데이터 베이스 >MySQL 튜토리얼 >MySQL 외래 키 제약 조건으로 데이터를 삭제할 때 고아 레코드를 방지하는 방법은 무엇입니까?

MySQL 외래 키 제약 조건으로 데이터를 삭제할 때 고아 레코드를 방지하는 방법은 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2024-12-29 11:55:10433검색

How to Prevent Orphaned Records When Deleting Data with MySQL Foreign Key Constraints?

MySQL 외래 키 제약 조건: 분리된 레코드 삭제

데이터베이스는 종종 외래 키 제약 조건을 통해 테이블 ​​간의 관계를 유지합니다. 이러한 제약 조건은 고아 레코드(다른 테이블에 존재하지 않는 데이터를 참조하는 레코드)를 방지하여 데이터 무결성을 보장합니다. 이러한 맥락에서 우리는 MySQL의 외래 키에 대한 연속 삭제를 구현하는 방법을 살펴봅니다.

예시 시나리오

다음 표를 고려하세요.

  • 카테고리: 아이디, name
  • products: ID, name
  • categories_products: Category_id, product_id

categories_products 테이블은 많은 항목을 생성합니다. 다른 두 테이블 간의 다대 관계. 이제 카테고리를 삭제한다고 가정해 보겠습니다. 해당 제품이 다른 카테고리와도 연결되어 있는 경우 삭제되지 않도록 하려면 어떻게 해야 합니까?

연속 삭제 구현

원하는 동작을 달성하려면 다음을 수행해야 합니다. ON DELETE CASCADE 절을 사용하여 외래 키 제약 조건을 설정합니다. 하위 테이블(categories_products)에서 foreign_key_id 열을 정의할 때 이 절을 다음과 같이 지정할 수 있습니다.

FOREIGN KEY (category_id) REFERENCES categories (id) ON DELETE CASCADE

이 절은 카테고리가 삭제되면 카테고리가 삭제된 경우 카테고리_제품 테이블의 모든 해당 레코드도 삭제되도록 보장합니다. 삭제되었습니다. 그러나 거기에 정의된 외래 키 제약 조건이 없기 때문에 캐스케이드는 제품 테이블로 전파되지 않습니다.

예제 데모

다음이 있다고 가정합니다. 데이터:

  • 카테고리:

    • 빨간색, 녹색, 파란색, 흰색, 검정색
  • 제품:

    • 부츠, 장갑, 모자, 코트
  • categories_products:

    • 빨간 부츠, 녹색 장갑, 빨간 코트, 검은색 모자

삭제하면 '빨간색' 카테고리를 선택하면 다음 작업이 수행됩니다.

  • '빨간색' 카테고리 항목이 카테고리 테이블에서 제거됩니다.
  • '빨간 부츠' 및 '빨간 코트' 항목 카테고리_제품 테이블에서 제거됩니다.
  • '부츠' 및 '코트' 카테고리는 카테고리에 영향을 받지 않고 그대로 유지됩니다.
  • 제품 테이블에서 '부츠'와 '장갑'은 영향을 받지 않습니다.

이런 방식으로 계단식 삭제는 관련 관련 레코드만 제거하여 데이터 무결성을 보장합니다. 고아 레코드를 방지하고 테이블 간의 관계를 유지합니다.

위 내용은 MySQL 외래 키 제약 조건으로 데이터를 삭제할 때 고아 레코드를 방지하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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