집 >데이터 베이스 >MySQL 튜토리얼 >상위 레코드를 삭제한 경우 상위 레코드를 삭제하지 않고 MySQL에서 하위 레코드를 어떻게 삭제할 수 있습니까?
종속 데이터 삭제를 위해 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!