> 데이터 베이스 > MySQL 튜토리얼 > MySQL에서 동적 데이터 피벗을 수행하는 방법은 무엇입니까?

MySQL에서 동적 데이터 피벗을 수행하는 방법은 무엇입니까?

DDD
풀어 주다: 2025-01-06 07:35:43
원래의
897명이 탐색했습니다.

How to Perform Dynamic Data Pivoting in MySQL?

MySQL의 데이터 동적 피벗

데이터 피벗은 데이터 변환의 일반적인 작업으로, 데이터를 세로 레이아웃에서 가로 레이아웃으로 재구성합니다. SQL에서는 UNPIVOT 또는 PIVOT 함수와 같은 다양한 기술을 사용하여 이를 달성할 수 있습니다. 그러나 MySQL에는 기본 PIVOT 기능이 없으므로 대체 방법을 모색해야 합니다.

MySQL의 동적 피보팅에 대한 한 가지 접근 방식은 집계 함수와 CASE 문을 사용하여 쿼리를 동적으로 구성하는 것입니다. 이 방법에는 출력에 필요한 차원과 값을 기반으로 SQL 문을 동적으로 작성하는 작업이 포함됩니다.

다음 예에서는 준비된 문을 사용하여 동적 피벗을 구현하는 방법을 보여줍니다.

SET @sql = NULL;
SELECT
  GROUP_CONCAT(DISTINCT
    CONCAT(
      'max(case when part_type = ''',
      part_type,
      ''' then part_id end) AS part_',
      part_type, '_id'
    )
  ) INTO @sql
FROM
  parts;
SET @sql = CONCAT('SELECT product_id, ', @sql, ' 
                  FROM parts 
                   GROUP BY product_id');

PREPARE stmt FROM @sql;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;
로그인 후 복사

이 쿼리에서 , 피벗의 차원인 고유한 부품 유형을 기반으로 SELECT 문을 동적으로 생성합니다. CASE 문을 사용하여 part_type을 기반으로 적절한 피벗 열에 part_id를 할당합니다. 그런 다음 생성된 SQL 문은 더 나은 성능을 위해 준비된 문을 사용하여 실행됩니다.

또 다른 옵션은 출력에 필요한 제한된 수의 열을 알고 있는 경우 쿼리의 정적 버전을 사용하는 것입니다.

select product_id,
  max(case when part_type ='A' then part_id end) as Part_A_Id,
  max(case when part_type ='B' then part_id end) as Part_B_Id
from parts
group by product_id
로그인 후 복사

이러한 기술을 활용하면 MySQL에서 동적 피버팅을 구현하여 데이터를 효율적으로 재구성할 수 있습니다.

위 내용은 MySQL에서 동적 데이터 피벗을 수행하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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