>데이터 베이스 >MySQL 튜토리얼 >SQL의 기존 외래 키 제약 조건에 'ON DELETE CASCADE'를 어떻게 추가할 수 있나요?

SQL의 기존 외래 키 제약 조건에 'ON DELETE CASCADE'를 어떻게 추가할 수 있나요?

Barbara Streisand
Barbara Streisand원래의
2024-12-17 10:26:25110검색

How Can I Add

SQL에서 제약 조건 수정

SQL에서 제약 조건은 데이터 무결성을 유지하고 테이블 내 데이터 일관성을 보장하는 데 중요한 역할을 합니다. 일반적인 작업 중 하나는 기존 제약 조건을 변경하여 해당 속성을 추가하거나 수정하는 것입니다. 이 문서에서는 제약 조건 변경 단계를 안내하며, 특히 기존 외래 키 제약 조건에 "ON DELETE CASCADE" 절을 추가하는 방법에 중점을 둡니다.

원래 제약 조건:

다음이라는 이름의 기존 외래 키 제약 조건이 있다고 가정합니다. ACTIVEPROG_FKEY1:

CONSTRAINT ACTIVEPROG_FKEY1 FOREIGN KEY(ActiveProgCode) REFERENCES PROGRAM(ActiveProgCode),

제약조건 변경:

기존 제약조건에 "ON DELETE CASCADE" 절을 추가하려고 합니다. 이 절은 상위 테이블(PROGRAM)에서 레코드가 삭제되면 하위 테이블(ACTIVEPROG)의 해당 레코드도 자동으로 삭제되도록 지정합니다.

제약 조건 변경 단계:

그러나 다른 데이터베이스 개체와 달리 제약 조건은 직접 수정을 지원하지 않습니다. 대신 기존 제약 조건을 삭제하고 원하는 대로 수정하여 다시 만들어야 합니다.

  1. 기존 제약 조건 삭제:

    ALTER TABLE your_table DROP CONSTRAINT ACTIVEPROG_FKEY1;
  2. "ON DELETE"를 사용하여 제약조건을 다시 생성합니다. CASCADE":

    ALTER TABLE your_table
    ADD CONSTRAINT ACTIVEPROG_FKEY1 FOREIGN KEY(ActiveProgCode) REFERENCES PROGRAM(ActiveProgCode)
    ON DELETE CASCADE;

이 단계를 수행하면 기존 제약 조건 ACTIVEPROG_FKEY1을 성공적으로 변경하여 "ON DELETE CASCADE" 절을 추가할 수 있습니다. 이렇게 하면 상위 테이블의 삭제가 자동으로 하위 테이블의 관련 레코드 연속 삭제를 트리거합니다.

위 내용은 SQL의 기존 외래 키 제약 조건에 'ON DELETE CASCADE'를 어떻게 추가할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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