집 >데이터 베이스 >MySQL 튜토리얼 >단일 테이블 상속 또는 클래스 테이블 상속: 다중 사용자 데이터베이스에 적합한 것은 무엇입니까?
여러 사용자 유형을 위한 관계형 데이터베이스 설계
여러 사용자 유형을 수용하는 관계형 데이터베이스를 설계할 때는 효율적인 저장 공간과 사용자 데이터 검색. 이 시나리오를 처리하기 위한 두 가지 주요 접근 방식은 다음과 같습니다.
단일 테이블 상속(STI)
STI에는 "판별자"를 사용하여 모든 사용자 유형에 대한 단일 테이블을 생성하는 작업이 포함됩니다. 각 행의 특정 유형을 나타내는 열입니다. 특정 사용자 유형에 적용할 수 없는 열은 NULL로 남습니다.
장점:
단점:
클래스 테이블 상속 (CTI)
CTI는 STI와 달리 사용자 유형별로 별도의 테이블을 사용합니다. 공통 "사용자" 테이블에는 공유 정보가 저장되고, 유형별 테이블에는 하위 클래스 종속 데이터가 포함됩니다. 하위 클래스 테이블은 일반적으로 외래 키를 사용하여 "users" 테이블에서 일치하는 행을 참조합니다.
장점:
공유 기본 키 설계(SPK)
CTI의 변형인 SPK에는 기본 키 설정이 포함됩니다. 서브클래스 테이블의 키는 "users" 테이블의 해당 행에 있는 기본 키의 복사본이 됩니다. 이 기술은 테이블 간의 기본 키와 외래 키 관계를 모두 보장합니다.
장점:
STI와 CTI 사이의 선택은 애플리케이션의 특정 요구 사항에 따라 달라집니다. STI는 다양한 사용자 유형이 유사한 데이터 구조를 갖고 있고 유형 전반에 걸쳐 효율적인 데이터 검색이 필요한 경우에 적합합니다. CTI는 데이터 구조가 상당히 다양하고 참조 무결성과 맞춤형 저장이 중요한 경우에 선호됩니다. SPK는 성능을 향상하고 일대일 관계를 강화하여 CTI를 향상시킵니다.
위 내용은 단일 테이블 상속 또는 클래스 테이블 상속: 다중 사용자 데이터베이스에 적합한 것은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!