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;
결과는 다음과 같다.
이와 같이 행/열을 바꾸어 결과를 출력할 수 있다.
'MySQL' 카테고리의 다른 글
[MYSQL] 에러 번호 1175 Safe Update 해결방법 (0) | 2018.07.17 |
---|---|
[MYSQL] 쿼리에서 변수 활용하기 SET (1) | 2018.06.19 |
[MYSQL] 오늘, 어제, 내일 날짜 자동으로 입력하기 curdate() (0) | 2018.06.12 |
[MySQL] 날짜, 시간 표기 방식 지정하기 DATE_FORMAT() (0) | 2017.12.31 |
[MySQL] 결과를 특정 순서로 정렬하기 ORDER BY FIELD() (2) | 2017.12.29 |
[MySQL] 데이터 변경하기 UPDATE (0) | 2017.12.28 |
[MySQL] 데이터 삭제하기 DELETE, TRUNCATE (1) | 2017.12.27 |
[MySQL] 테이블에 데이터 입력하기 INSERT INTO (0) | 2017.12.10 |
[MySQL] 테이블 이름 확인하기 SHOW TABLES (0) | 2017.12.08 |
[MySQL] DB에서 특정 행들만 가져오기(1) - WHERE 절의 "or"를 이용 (0) | 2017.09.08 |
댓글