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

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

DDD
풀어 주다: 2024-12-08 14:24:15
원래의
329명이 탐색했습니다.

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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