집 >데이터 베이스 >MySQL 튜토리얼 >MySQL에서 '자식 행을 추가하거나 업데이트할 수 없습니다. 외래 키 제약 조건이 실패합니다'(오류 1452)가 발생하는 이유는 무엇입니까?
MySQL 외래 키 제약 조건 문제: 하위 행을 추가하거나 업데이트할 수 없음
MySQL 테이블에 외래 키 제약 조건을 설정하려고 하면 오류 1452: "하위 행을 추가하거나 업데이트할 수 없습니다. 외래 키 제약 조건이 실패합니다."가 발생할 수 있습니다. 이 문제는 한 테이블의 하위 행이 다른 테이블에 더 이상 존재하지 않는 상위 행을 참조할 때 발생합니다.
제공된 시나리오에서는 소스 코드 테이블을 참조하는 sourcecodes_tags 테이블에 외래 키를 추가하려고 합니다. 그러나 오류 메시지는 sourcecodes 테이블에 존재하지 않는 행을 참조하는 sourcecodes_tags 테이블에 고아 레코드가 있음을 나타냅니다.
이 문제를 해결하려면 먼저 고아 레코드를 식별해야 합니다. 다음 쿼리를 사용하여 이러한 레코드를 검색할 수 있습니다.
SELECT DISTINCT sourcecode_id FROM sourcecodes_tags tags LEFT JOIN sourcecodes sc ON tags.sourcecode_id=sc.id WHERE sc.id IS NULL;
고아 레코드를 식별한 후에는 sourcecodes_tags 테이블에서 해당 레코드를 제거할 수 있습니다. 이렇게 하면 외래 키 제약 조건을 성공적으로 추가할 수 있습니다.
외래 키 제약 조건을 적용하여 데이터베이스 테이블의 참조 무결성을 보장하는 것이 중요합니다. 이러한 제약 조건은 데이터 불일치를 방지하고 테이블 간의 관계를 유지합니다. 분리된 레코드를 처리하면 오류 1452를 해결하고 데이터베이스 테이블 간의 적절한 관계를 설정할 수 있습니다.
위 내용은 MySQL에서 '자식 행을 추가하거나 업데이트할 수 없습니다. 외래 키 제약 조건이 실패합니다'(오류 1452)가 발생하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!