EAV 데이터베이스 설계: 기록 데이터 관리 접근 방식
EAV(엔티티-속성-값) 데이터베이스 모델은 잠재적인 데이터 무결성 및 보고 문제로 종종 비판을 받기도 하지만 기록 데이터를 추적하고 SQL과 키-값 저장소 환경을 연결하는 데 이점을 제공합니다. 이 기사에서는 이러한 우려를 완화하기 위한 개선된 EAV 접근 방식을 살펴봅니다.
데이터 유형별로 항목 속성 구성
기존 EAV의 주요 개선 사항은 데이터 유형에 따라 엔터티 속성을 분리하는 것입니다. 이를 통해 관계(예: "belongsTo", "has", "hasMany", "hasManyThrough") 관리가 용이해지고 속성 및 엔터티의 적절한 인덱싱이 가능해집니다.
제안된 관계형 스키마
다음 관계형 데이터베이스 스키마가 제안됩니다.
<code class="language-sql">entity_type { id, type, -- e.g., "product," "user" created_at } entity { id, entity_type_id, created_at } attr { id, entity_id, type, name, created_at } option { id, attr_id, entity_id, multiple, -- Allow multiple values name, created_at } attr_option { id, attr_id, entity_id, option_id, option, created_at } -- Additional tables for various attribute types (e.g., attr_int, attr_datetime)</code>
이력 데이터 추적
이 스키마를 사용하면 새로운 속성 값을 추가하고 타임스탬프를 활용하여 최신 변경 사항을 식별함으로써 기록 데이터 추적이 가능합니다. 이렇게 하면 전체 수정 내역을 보존하면서 데이터 업데이트가 필요하지 않습니다.
예시 쿼리
데이터 검색을 보여주는 쿼리 예시:
항목 유형 검색:
<code class="language-sql"> SELECT * FROM entity_type et LEFT JOIN entity e ON e.entity_type_id = et.id WHERE e.id = ?</code>
엔티티 속성 검색:
<code class="language-sql"> SELECT * FROM attr WHERE entity_id = ?</code>
속성 값 검색(단일 및 다중 값):
<code class="language-sql"> SELECT * FROM attr_option WHERE entity_id = ? AND multiple = 0 ORDER BY created_at DESC LIMIT 1 -- Single Value SELECT * FROM attr_int WHERE entity_id = ? ORDER BY created_at DESC LIMIT 1 -- Integer Value -- ... other attribute type queries</code>
관계 검색:
<code class="language-sql"> SELECT * FROM entity AS e LEFT JOIN attr_relation AS ar ON ar.entity_id = e.id WHERE ar.entity_id = 34 AND e.entity_type = 2;</code>
도전과 고려사항
이러한 접근 방식에는 이점에도 불구하고 다음과 같은 몇 가지 과제가 있습니다.
위 내용은 EAV 데이터베이스 설계가 효율적인 기록 데이터 관리를 위한 올바른 솔루션입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!