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

MySQL에서 동적 열을 행으로 피벗 해제하는 방법은 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2024-12-10 07:46:09836검색

How to Unpivot Dynamic Columns into Rows in MySQL?

동적 열에서 행 생성

데이터 관리 영역에서는 열과 행을 조작해야 하는 경우가 많습니다. 이 질문은 특정 작업, 즉 여러 동적 열을 특정 기준이 포함된 행이 있는 새 테이블로 변환하는 것에 대해 자세히 설명합니다.

주어진 예는 Table_1의 피벗 해제로 인해 Expected_Result_Table이 발생하는 것을 보여줍니다. 주요 차이점은 Expected_Result_Table은 0이 아닌 각 값을 별도의 행에 표시한다는 것입니다.

MySQL에는 직접적인 UNPIVOT 함수가 없지만 UNION ALL 문을 사용하여 이 제한을 극복할 수 있습니다. 기본 접근 방식에는 각 열에 대해 별도의 SELECT 문을 만들고, ID를 선택하고, 열 이름을 "단어" 값으로, 열 값을 "qty" 값으로 선택하는 작업이 포함됩니다. 그런 다음 이러한 SELECT 문은 UNION ALL을 사용하여 결합됩니다.

예:

SELECT id, 'abc' AS word, abc AS qty
FROM yt
WHERE abc > 0
UNION ALL
SELECT id, 'brt', brt
FROM yt
WHERE brt > 0

이 접근 방식은 동적 열을 처리할 때 더욱 복잡해집니다. 이 문제를 해결하기 위해 준비된 진술을 사용할 수 있습니다. 메타데이터를 기반으로 SQL 문을 동적으로 생성할 수 있습니다.

다음 코드 조각은 이러한 접근 방식을 보여줍니다.

SET @sql = NULL;

SELECT
  GROUP_CONCAT(DISTINCT
    CONCAT(
      'select id, ''',
      c.column_name,
      ''' as word, ',
      c.column_name,
      ' as qty 
      from yt 
      where ',
      c.column_name,
      ' > 0'
    ) SEPARATOR ' UNION ALL '
  ) INTO @sql
FROM information_schema.columns c
WHERE c.table_name = 'yt'
  AND c.column_name NOT IN ('id')
ORDER BY c.ordinal_position;

SET @sql 
  = CONCAT('select id, word, qty
           from
           (', @sql, ') x  order by id');


PREPARE stmt FROM @sql;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;

이 예에서 동적 SQL은 다음의 정보를 사용하여 구성됩니다. information_schema.columns 테이블입니다. 그런 다음 준비된 문 stmt를 사용하여 동적으로 생성된 SQL을 실행하고 동적 열을 행으로 효과적으로 피벗 해제합니다.

이 접근 방식을 구현하면 특정 데이터 요구 사항에 맞게 동적 열을 행으로 변환할 수 있습니다.

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

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