> 데이터 베이스 > MySQL 튜토리얼 > 조건부 외래 키 제약 조건 없이 MySQL에서 다형성 연관을 어떻게 구현할 수 있습니까?

조건부 외래 키 제약 조건 없이 MySQL에서 다형성 연관을 어떻게 구현할 수 있습니까?

Barbara Streisand
풀어 주다: 2025-01-16 11:50:58
원래의
822명이 탐색했습니다.

How Can I Implement Polymorphic Associations in MySQL Without Conditional Foreign Key Constraints?

MySQL 다형성 연관: 외래 키 제한 극복

단일 외래 키가 여러 테이블을 가리킬 수 있는 다형성 연관은 외래 키 제약 조건의 엄격한 특성으로 인해 MySQL에서 문제를 야기합니다. 표준 외래 키에는 고정된 대상 테이블이 필요하므로 조건부 참조가 불가능합니다.

해결책은 '슈퍼테이블' 전략에 있습니다. Commentable라고 부르는 중앙 테이블이 중개자 역할을 합니다. 이 테이블에는 고유 식별자(유사 키)가 포함되어 있으며 다형성 연관이 필요한 다른 모든 테이블에 대한 공통 참조 지점 역할을 합니다.

이 접근 방식은 객체 지향 설계 원칙을 반영합니다. BlogPostsUserPictures과 같은 테이블은 사실상 이 공유 식별자를 통해 Commentable 상위 테이블에서 상속됩니다. 이 공유 id는 다양한 콘텐츠 유형에 걸쳐 데이터 무결성을 유지합니다.

중요하게, 하위 유형 테이블(예: BlogPosts)에 레코드를 추가하기 전에 먼저 Commentable 테이블에 해당 항목을 생성하여 유사 키를 생성해야 합니다. 이를 통해 다형성 연관의 복잡성을 수용하면서 전통적인 외래 키 시스템의 동작을 모방하여 관계가 적절하게 관리될 수 있습니다.

위 내용은 조건부 외래 키 제약 조건 없이 MySQL에서 다형성 연관을 어떻게 구현할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿