> 데이터 베이스 > MySQL 튜토리얼 > 작업 기록을 삭제하면 '외래 키 제약 조건 위반'이 발생하는 이유는 무엇입니까?

작업 기록을 삭제하면 '외래 키 제약 조건 위반'이 발생하는 이유는 무엇입니까?

Linda Hamilton
풀어 주다: 2025-01-14 16:27:48
원래의
177명이 탐색했습니다.

Why Does Deleting a Job Record Cause a

외래 키 제약 조건 위반: "상위 행을 삭제하거나 업데이트할 수 없습니다."

작업 레코드를 삭제하면 "상위 행을 삭제하거나 업데이트할 수 없습니다. 외래 키 제약 조건이 실패합니다."(#1451) 오류가 발생할 수 있습니다. 이는 jobs 테이블과 advertisers 테이블 간의 외래 키 관계로 인해 발생합니다.

외래 키 제약 조건 이해

외래 키 제약 조건은 참조 무결성을 보장합니다. jobs 테이블의 advertiser_id 열은 항상 advertiser_id 테이블의 유효한 advertisers과 일치해야 합니다. 이렇게 하면 고아 레코드가 방지됩니다. 해당 오류는 채용정보가 광고주와 연결되어 있을 때 발생하며, 채용정보를 삭제하면 참조사항이 남게 됩니다.

솔루션

1. 외래 키 확인을 일시적으로 비활성화:

가장 빠른 해결 방법은 외래 키 확인을 일시적으로 비활성화하고 작업을 삭제한 후 다시 활성화하는 것입니다.

<code class="language-sql">SET FOREIGN_KEY_CHECKS=0;
DELETE FROM `jobs` WHERE `job_id` = 1 LIMIT 1;
SET FOREIGN_KEY_CHECKS=1;</code>
로그인 후 복사

이 방법은 제약 조건을 우회하지만 나중에 데이터 무결성 검사를 다시 활성화하는 데 중요합니다.

2. 계단식 삭제 구현:

더 강력한 솔루션은 계단식 삭제를 사용하도록 외래 키 제약 조건을 수정하는 것입니다. 작업이 제거되면 연결된 광고주 기록이 자동으로 삭제됩니다.

<code class="language-sql">ALTER TABLE `advertisers`
ADD CONSTRAINT `advertisers_ibfk_1` FOREIGN KEY (`advertiser_id`) REFERENCES `jobs` (`advertiser_id`) ON DELETE CASCADE;</code>
로그인 후 복사

계단 삭제는 임시 제약 조건을 비활성화하지 않고도 데이터 일관성을 유지합니다. 더욱 깔끔하고 유지 관리가 용이한 데이터베이스 디자인을 위해 이 접근 방식을 선택하세요.

위 내용은 작업 기록을 삭제하면 '외래 키 제약 조건 위반'이 발생하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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