>데이터 베이스 >MySQL 튜토리얼 >효율적인 데이터 검색을 위해 MySQL EAV(엔터티 속성 값) 스키마를 어떻게 피벗할 수 있습니까?

효율적인 데이터 검색을 위해 MySQL EAV(엔터티 속성 값) 스키마를 어떻게 피벗할 수 있습니까?

DDD
DDD원래의
2024-12-08 14:24:15328검색

How Can I Pivot a MySQL Entity-Attribute-Value (EAV) Schema for Efficient Data Retrieval?

MySQL 엔터티-속성-값 스키마 피벗

엔티티-속성-값(EAV) 스키마를 피벗해야 할 필요성은 다음과 같은 경우에 발생합니다. 사전에 결정할 수 없는 많은 사용자 정의 메타데이터 필드. 이 문제를 해결하려면 파일에 대한 공통 메타데이터, 선택적 속성 및 속성 값을 저장하는 테이블을 생성할 수 있습니다.

다음 스키마를 고려하세요.

CREATE TABLE FileBase (
    id VARCHAR(32) PRIMARY KEY,
    name VARCHAR(255) UNIQUE NOT NULL,
    title VARCHAR(255),
    author VARCHAR(255),
    created DATETIME NOT NULL,
);

CREATE TABLE Attributes (
    id VARCHAR(32) PRIMARY KEY,
    name VARCHAR(255) NOT NULL,
    type VARCHAR(255) NOT NULL
);

CREATE TABLE FileAttributes (
    sNo INT UNSIGNED PRIMARY KEY AUTO_INCREMENT,
    fileId VARCHAR(32) NOT NULL,
    attributeId VARCHAR(32) NOT NULL,
    attributeValue VARCHAR(255) NOT NULL,
    FOREIGN KEY fileId REFERENCES FileBase (id),
    FOREIGN KEY attributeId REFERENCES Attributes (id)
);

원하는 형식으로 데이터를 검색하려면 , MySQL에서 GROUP_CONCAT() 함수를 활용할 수 있습니다:

위 내용은 효율적인 데이터 검색을 위해 MySQL EAV(엔터티 속성 값) 스키마를 어떻게 피벗할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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