DB/Oracle

SUM() OVER() ORACLE 내장 함수 ORACLE

벨포트조던 2016. 2. 17.
반응형

출처 : 안재광 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도 추가로 알면 개발할 때 유용할 것이다.


반응형

댓글