>데이터 베이스 >MySQL 튜토리얼 >ON DELETE CASCADE에서 ON DELETE RESTRICT로 외래 키의 참조 작업을 변경하는 방법은 무엇입니까?

ON DELETE CASCADE에서 ON DELETE RESTRICT로 외래 키의 참조 작업을 변경하는 방법은 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2024-12-04 10:53:14593검색

How to Change a Foreign Key's Referential Action from ON DELETE CASCADE to 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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