집 >데이터 베이스 >MySQL 튜토리얼 >`CASE` 또는 `IF` 문을 사용하여 MySQL에서 데이터를 피벗하는 방법은 무엇입니까?
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!