[MySQL] 행, 열 바꾸어 출력하기 CASE ~ AS
sandbox 테이블에 다음과 같은 자료를 입력하고 cat1, cat2, cat3 의 합계를 구해 보자.
INSERT INTO sandbox
(name, value, note)
VALUES
('a',174,'cat1'),
('b',164,'cat2'),
('c',168,'cat3'),
('d',170,'cat1'),
('e',197,'cat2'),
('f',109,'cat3'),
('g',139,'cat1'),
('h',138,'cat2'),
('i',197,'cat3'),
('j',146,'cat1'),
('k',148,'cat2'),
('l',112,'cat3'),
('m',137,'cat1'),
('n',119,'cat2'),
('o',167,'cat3');
합계는 다음과 같이 구하면 되겠다.
SELECT note, sum(value) FROM `sandbox` group by note;
이제 이것을 다음과 같이 행, 열을 바꾸어 출력하려면 어떻게 해야 할까?
엑셀의 TRANSPOSE() 같은 명령이 하나 있으면 될 것 같은데, 아쉽게도 mySQL에는 TRANSPOSE가 없다.
대신 원하는 결과를 얻기 위해 사용되는 것이 2017/07/28 - [SQL] - [SQL] 일부 값만 음수로 계산하기 (조건문 CASE)에 등장했던 CASE다.
전략은 이렇다.
note가 cat1 에 해당하는 value 는 cat1 이라는 필드에 적는다.
note가 cat2 에 해당하는 value 는 cat2 라는 필드에 적는다.
note가 cat3 에 해당하는 value 는 cat3 라는 필드에 적는다.
그리고 마지막으로 각 필드에 분류된 value들을 필드별로 합한다.
일단 분류부터 해 보자.
다음과 같이 적으면 되겠다.
SELECT
case when note='cat1' then value end as 'cat1',
case when note='cat2' then value end as 'cat2',
case when note='cat3' then value end as 'cat3'
FROM sandbox;
결과는 다음과 같다.
한 행씩 데이터를 읽어, note가 cat1인 value 는 새로 만들어진 cat1 이라는 필드에, note가 cat2인 value 는 cat2라는 필드에 적고 있다.
이제 이것을 각 필드별로 합해주면 되겠다.
SELECT
sum(case when note='cat1' then value end) as 'cat1',
sum(case when note='cat2' then value end) as 'cat2',
sum(case when note='cat3' then value end) as 'cat3'
FROM sandbox;
결과는 다음과 같다.
이와 같이 행/열을 바꾸어 결과를 출력할 수 있다.