>데이터 베이스 >MySQL 튜토리얼 >MySQL에서 '자식 행을 추가하거나 업데이트할 수 없습니다. 외래 키 제약 조건이 실패합니다'(오류 1452)가 발생하는 이유는 무엇입니까?

MySQL에서 '자식 행을 추가하거나 업데이트할 수 없습니다. 외래 키 제약 조건이 실패합니다'(오류 1452)가 발생하는 이유는 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2024-12-21 00:01:11148검색

Why Does MySQL Throw

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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