`CASE` 또는 `IF` 문을 사용하여 MySQL에서 데이터를 피벗하는 방법은 무엇입니까?

Linda Hamilton
풀어 주다: 2024-11-09 10:05:02
원래의
188명이 탐색했습니다.

How to Pivot Data in MySQL Using `CASE` or `IF` Statements?

GROUP BY를 사용하여 피벗 형식으로 데이터 표시

당면 작업에는 개별 데이터 포인트를 나타내는 행이 있는 관계형 데이터베이스 테이블을 데이터가 타임스탬프를 기준으로 열로 구성되고 값이 특정 식별자로 그룹화되는 피벗 형식입니다.

이 피벗 구조를 달성하기 위해 MySQL에서 CASE 문을 사용할 수 있습니다. 이 문을 사용하면 다양한 조건에 따라 조건부로 값을 할당할 수 있습니다.

SELECT d.data_timestamp
, SUM( CASE WHEN data_id = 1 THEN data_value ELSE 0 END ) AS 'input_1'
, SUM( CASE WHEN data_id = 2 THEN data_value ELSE 0 END ) AS 'input_2'
...
, SUM( CASE WHEN data_id = 20 THEN data_value ELSE 0 END ) AS 'input_20'
FROM data
GROUP BY data_timestamp
ORDER BY data_timestamp ASC
로그인 후 복사

이 쿼리에서는 SUM 함수를 사용하여 각 개별 data_timestamp에 대한 data_value를 집계합니다. CASE 문은 data_id가 특정 값(예: 1, 2, 20)과 일치하는지 확인합니다. 일치하면 해당 data_value가 해당 열(예: input_1, input_2, input_20)의 합계에 포함됩니다. 일치하는 항목이 없으면 계산에 0이 사용됩니다. 그러면 data_timestamp가 행 식별자이고 각 data_id에 해당 집계 data_value를 표시하는 전용 열이 있는 테이블이 생성됩니다.

동일한 목적으로 CASE 대신 IF 문을 활용할 수도 있습니다.

SELECT d.data_timestamp
, SUM( IF(data_id = 1, data_value, 0) ) AS 'input_1'
, SUM( IF(data_id = 2, data_value, 0) ) AS 'input_2'
...
, SUM( IF(data_id = 20, data_value, 0) ) AS 'input_20'
FROM data
GROUP BY data_timestamp
ORDER BY data_timestamp ASC
로그인 후 복사

CASE와 IF 접근 방식을 모두 사용하면 필요한 열을 동적으로 생성하고 data_id 및 data_timestamp를 기반으로 값을 집계하여 궁극적으로 원하는 피벗 형식으로 데이터를 표시할 수 있습니다.

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

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