[oracle]오라클 group by, rollup :: 개발/일상_Mr.lee

[oracle]오라클 group by, rollup

Posted by Mr.mandu.
2016. 5. 20. 02:30 개발/DB
프로그래밍의 실력을 쌓는 법!은~
기초를 탄탄하게 중요하다고 생각합니다.

평소 무심코 썼던 group by....
왜 무심코 쓰게 되냐면 기존의 프로젝트에 새로운 컬럼을 추가하고자 하면
group by 형식이 아니라는 오류 메시지가 뜨죠...

그럼 그냥 group by 절에 컬럼을 추가해서 에러를 제거하고 프로그램을 안전하게 돌립니다....

그래서 그냥 막 쓰기보다는 제대로 정리하자 라는 취지에서 포스팅을 하려고 합니다.

group by의 개념은...말그래도 그룹을 짓는다! 입니다.

그냥 예제로 살펴보는게 이해가 빠르실 겁니다.

먼저 전체 테이블 확인하겠습니다.


여기에 가장 기초적인 단순 컬럼 하나를 그룹 지어보겠습니다.
position별로 그룹지어보겠습니다.

select
position
from
professor
group by position
;

결과는
입니다.

row수가 3개로 나타났죠? 정교수, 전임강사, 조교수 딱 position별 데이터만 나왔습니다.


다음의 쿼리를 보시죠.
 

select

position, sum(bonus)

from

professor

group by position



sum함수를 이용하여 각 position 별 보너스의 합계를 구했습니다.





그리고 이번에는 
rollup을 이용하여 소계를 구해보겠습니다.

rollup의 활용법입니다. 유의깊게 보세요^^


SELECT
position, SUM(bonus)
FROM
PROFESSOR
GROUP BY ROLLUP(position)

결과는

4행에 780이라고 합계가 나오지 않았습니까???
이렇게 총계를 구할때 rollup을 사용합니다.

알아두면 필요시에 사용할 곳이 있을거라고 생각합니다.

그리고 이번엔 group by rollup에 2개의 컬럼을 넣어보겠습니다.
먼저 position,  subject을 넣어보겠습니다.

SELECT
position, subject, SUM(bonus)
FROM
PROFESSOR
GROUP BY ROLLUP(position,  subject)
;

rollup을 보시면 순서가 position, subject입니다.  그랬더니 
교수 직책별 보너스를 구할 수 있었습니다.

이번에는 과목별 보너스 합계를 구해보겠습니다.

//과목별
SELECT
subject, position, SUM(bonus)
FROM
PROFESSOR
GROUP BY ROLLUP(subject, position)
;


이번엔 과목별 소계와 합계가 나온 것을 확인 할 수 있습니다.


SELECT
position , subject, SUM(bonus)
FROM
PROFESSOR
GROUP BY ROLLUP(position,  subject) HAVING GROUPING_id(position,  subject) IN(0,3)
;

이번엔 소계는 제외하고 총 합계만 구해보도록 하겠습니다.


총 합계를 구하기위해 
having grouping_id를 사용 하였는데요 조건을 보면 0 과 3만 출력하고 있습니다.
무슨 의미인지 확인해보기위해서 포스팅한 제 포스팅을 참고하셔도 좋습니다.


요번에는 최종합계에 null 처리되어있던 칼럼을 '합계'로 이름을 주어 출력해보도록 하겠습니다.

 SELECT
DECODE(position, NULL, '합계', position), subject, SUM(bonus)
FROM
PROFESSOR
GROUP BY ROLLUP(position,  subject) HAVING GROUPING_id(position,  subject) IN(0,3)

;