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 중국어 웹사이트의 기타 관련 기사를 참조하세요!