단일 외래 키가 여러 테이블을 가리킬 수 있는 다형성 연관은 외래 키 제약 조건의 엄격한 특성으로 인해 MySQL에서 문제를 야기합니다. 표준 외래 키에는 고정된 대상 테이블이 필요하므로 조건부 참조가 불가능합니다.
해결책은 '슈퍼테이블' 전략에 있습니다. Commentable
라고 부르는 중앙 테이블이 중개자 역할을 합니다. 이 테이블에는 고유 식별자(유사 키)가 포함되어 있으며 다형성 연관이 필요한 다른 모든 테이블에 대한 공통 참조 지점 역할을 합니다.
이 접근 방식은 객체 지향 설계 원칙을 반영합니다. BlogPosts
및 UserPictures
과 같은 테이블은 사실상 이 공유 식별자를 통해 Commentable
상위 테이블에서 상속됩니다. 이 공유 id
는 다양한 콘텐츠 유형에 걸쳐 데이터 무결성을 유지합니다.
중요하게, 하위 유형 테이블(예: BlogPosts
)에 레코드를 추가하기 전에 먼저 Commentable
테이블에 해당 항목을 생성하여 유사 키를 생성해야 합니다. 이를 통해 다형성 연관의 복잡성을 수용하면서 전통적인 외래 키 시스템의 동작을 모방하여 관계가 적절하게 관리될 수 있습니다.
위 내용은 조건부 외래 키 제약 조건 없이 MySQL에서 다형성 연관을 어떻게 구현할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!