>데이터 베이스 >MySQL 튜토리얼 >상위 레코드를 삭제한 경우 상위 레코드를 삭제하지 않고 MySQL에서 하위 레코드를 어떻게 삭제할 수 있습니까?

상위 레코드를 삭제한 경우 상위 레코드를 삭제하지 않고 MySQL에서 하위 레코드를 어떻게 삭제할 수 있습니까?

Patricia Arquette
Patricia Arquette원래의
2025-01-10 12:17:42424검색

How to Delete Child Records in MySQL When a Parent Record is Deleted (Without Deleting the Parent)

종속 데이터 삭제를 위해 MySQL의 ON DELETE CASCADE 활용

데이터 무결성을 유지하려면 상위 기록 삭제 시 관련 데이터를 자동으로 제거해야 하는 경우가 많습니다. MySQL의 ON DELETE CASCADE 제약 조건이 이 기능을 제공합니다. 일반적인 오해는 이 제약 조건이 하위 레코드가 삭제될 때 상위 레코드도 삭제한다는 것입니다. 이는 잘못된 정보입니다.

원하는 동작(상위(유형) 레코드가 삭제될 때 상위 레코드에 영향을 주지 않고 하위(구성 요소) 레코드 삭제)을 달성하려면 ON DELETE CASCADE을 사용하여 하위 테이블에 외래 키 관계를 정의해야 합니다. 다음은 components 테이블에 대해 이를 보여줍니다.

<code class="language-sql">CREATE TABLE `components` (
    `id` int(10) unsigned NOT NULL auto_increment,
    `typeId` int(10) unsigned NOT NULL,
    `moreInfo` VARCHAR(32),
    -- etc
    PRIMARY KEY (`id`),
    KEY `type` (`typeId`),
    CONSTRAINT `myForeignKey` FOREIGN KEY (`typeId`)
      REFERENCES `types` (`id`) ON DELETE CASCADE ON UPDATE CASCADE
);</code>

이 구성을 사용하면 types 테이블에서 레코드를 삭제하면 components 테이블의 해당 항목이 모두 자동으로 삭제되고 types 테이블 레코드는 그대로 유지됩니다.

중요 고려 사항:

외래 키 제약 조건에는 InnoDB 스토리지 엔진을 사용해야 한다는 점을 기억하세요. 이전 MySQL 버전의 기본 엔진인 MyISAM은 외래 키를 지원하지 않습니다. 따라서 이 기능이 올바르게 작동하려면 테이블에서 InnoDB를 사용하고 있는지 확인하세요.

위 내용은 상위 레코드를 삭제한 경우 상위 레코드를 삭제하지 않고 MySQL에서 하위 레코드를 어떻게 삭제할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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