본문 바로가기
MySQL

[MySQL] 행, 열 바꾸어 출력하기 CASE ~ AS

by LightBlogger 2017. 12. 30.

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;


결과는 다음과 같다.



이와 같이 행/열을 바꾸어 결과를 출력할 수 있다.




반응형

댓글