집 >데이터 베이스 >MySQL 튜토리얼 >ON DELETE CASCADE에서 ON DELETE RESTRICT로 외래 키의 참조 작업을 변경하는 방법은 무엇입니까?
외래 키 참조 동작 변경
외래 키 제약 조건은 테이블 간 관계를 설정하여 데이터 무결성을 강화합니다. 일반적인 시나리오 중 하나는 참조 레코드가 삭제될 때의 동작을 관리하는 것입니다. 이 문서에서는 특히 ON DELETE CASCADE에서 ON DELETE RESTRICT로 참조 작업을 변경하는 방법을 다룹니다.
ON DELETE CASCADE와 ON DELETE RESTRICT
ON DELETE CASCADE: 상위 레코드가 삭제되면 일치하는 모든 하위 레코드가 자동으로 삭제됩니다. 이 동작은 의도하지 않은 데이터 손실로 이어질 수 있습니다.
ON DELETE RESTRICT: 하위 레코드가 있는 경우 상위 레코드 삭제를 방지합니다. 이렇게 하면 데이터 무결성이 유지됩니다.
참조 작업을 변경하는 SQL 명령
다음 SQL 명령은 외래 키 열에 대한 참조 작업을 수정합니다.
ALTER TABLE <table_name> ADD CONSTRAINT <constraint_name> FOREIGN KEY (<column_name>) REFERENCES <referenced_table_name> ON DELETE <referential_action>
귀하의 경우 table_name은 "table1"이고, Constraint_name은 "fk_table2_id"이며, column_name은 "fk_table2_id"이고, reference_table_name은 "table2"이며,referential_action은 "RESTRICT"입니다.
예
"table1"과 "table1"이라는 두 개의 테이블이 있다고 가정합니다. "table2":
CREATE TABLE table1 ( id INT NOT NULL, fk_table2_id INT NOT NULL, PRIMARY KEY (id), FOREIGN KEY (fk_table2_id) REFERENCES table2(id) ON DELETE CASCADE ); CREATE TABLE table2 ( id INT NOT NULL, PRIMARY KEY (id) );
변경하려면 ON DELETE RESTRICT에 대한 "table1"의 외래 키 제약 조건은 다음 명령을 실행합니다.
ALTER TABLE table1 ADD CONSTRAINT fk_table2_id FOREIGN KEY (fk_table2_id) REFERENCES table2(id) ON DELETE RESTRICT;
이렇게 하면 "table1"에서 이를 참조하는 하위 레코드가 아직 있는 경우 "table2"의 레코드가 삭제되지 않습니다. .
위 내용은 ON DELETE CASCADE에서 ON DELETE RESTRICT로 외래 키의 참조 작업을 변경하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!