출처 : 안재광 http://www.cyworld.com/ajkwin79/2741322
SCOTT 계정의 EMP TABLE에서 테스트를 진행한다
다음의 QUERY 을 보면 이해가 쉽다.
----------------------------------------------------------------------------------------------
SELECT ENAME,
DEPTNO,
SAL,
SUM(SAL) OVER (PARTITION BY DEPTNO) "부서별 급여합계",
SUM(SAL) OVER (PARTITION BY DEPTNO ORDER BY SAL) "부서별 급여오름차순 누적합",
SUM(SAL) OVER (ORDER BY DEPTNO, SAL) "부서별 급여오름차순 누적합",
SUM(SAL) OVER () "전체 급여합"
FROM EMP;
----------------------------------------------------------------------------------------------
위 QUERY 의 결과는 다음과 같다.
원래 SUM 함수는 GROUP 함수다.
따라서 위와 같은 부분에서 ENAME, DEPTNO, SAL 로 GROUP BY 을 해줘야 한다.
하지만 SUM() OVER()를 사용할 때는 GROUP BY 가 필요 없다
1. SUM(COLUMN1) OVER(PARTITION BY COLUMN2) --->
이는 특정 컬럼2로 그룹핑 한 컬럼1의 SUM 값을 보여준다
위에서처럼 부서별 급여합이 된다. 10부서, 20부서 등의 급여 합을 보여준다
2. SUM(COLUMN1) OVER(PARTITION BY COLUMN2 ORDER BY COLUMN1) --->
이는 위에서보는 것처럼 컬럼2로 그룹핑한 데이터를 컬럼1로 오름차순 정렬을 하면서 SUM을 구한다.
이는 위의 예에서 보는 부서별 급여의 누적된 합을 구할 때 쓸 수 있다.
여기서 위와 같은 부분은 PARTITION BY 않하고 정렬을 통해서도 구현이 가능하다
SUM(COLUMN1) OVER(ORDER BY COLUMN1, COLUMN1)
다음처럼 쓰면 PARTITION 한 것과 같은 결과를 얻을 수 있다.
3. SUM(COLUMN) OVER() --->
마지막으로 이는 컬럼의 전체 합을 리턴하게 된다..
GROUP BY 는 쓰는데 제약이 존재할 때가 있다.
난 개인적으로 그런 GROUP BY 를 싫어한다.
하지만 개발시에 그룹별로 보여줘야 할 부분은 너무 많다.
법인별, 부서별 등등의 어떤 내역 조회의 경우....
이는 불가피할 것이다.
이런 TIP도 추가로 알면 개발할 때 유용할 것이다.
'DB > Oracle' 카테고리의 다른 글
시퀀스를 안쓰는 이유 찾아보기 (0) | 2016.03.08 |
---|---|
시퀀스 사용안하고 인서트 하는 방법 (0) | 2016.03.08 |
각 컬럼의 값에 대하여 누적 합계 구하기. (0) | 2016.01.12 |
페이지, 페이징을 주기 위한 쿼리문 예제 (0) | 2015.12.29 |
공통코드 설계 (0) | 2015.09.04 |
댓글