집 >데이터 베이스 >MySQL 튜토리얼 >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 중국어 웹사이트의 기타 관련 기사를 참조하세요!