ROLLUP 질문입니다. GROUPING =1 일때 비율(RATIO_TO_REPORT) 관련입니다. 0 2 3,064

by 허승호 [2016.03.31 17:06:39]


아래의 SQL을 실행시키면 결과가 원하는 결과가 나오지 않습니다..

WITH R AS (
SELECT 1 AS X FROM DUAL UNION ALL
SELECT 1 AS X FROM DUAL UNION ALL
SELECT 1 AS X FROM DUAL UNION ALL
SELECT 2 AS X FROM DUAL UNION ALL
SELECT 2 FROM DUAL 
)
SELECT X
​   	   , GROUPING(X) 
	   , COUNT(*) AS CNT 
	   , RATIO_TO_REPORT(COUNT(X) ) OVER () * 100 || '%' AS RATIO 
  FROM R GROUP BY ROLLUP(X) 

 

출력값 GROUPING = 1 부분에 100%라는 숫자가 원하는데 50%만 나오는건.. 어케 해결해야 할까요. 원인은 알겠는데..

방법이 떠오르질 않네요.. 

by 허승호 [2016.03.31 17:10:25]

ㅋㅋㅋ 해결했습니다.  자문 자답이네요.. 부끄럽네요. ㅎㅎ
 

WITH R AS (
SELECT 1 AS X FROM DUAL UNION ALL
SELECT 1 AS X FROM DUAL UNION ALL
SELECT 1 AS X FROM DUAL UNION ALL
SELECT 2 AS X FROM DUAL UNION ALL
SELECT 2 FROM DUAL 
)
SELECT X
​          , GROUPING(X) 
       , COUNT(*) AS CNT 
       , RATIO_TO_REPORT(COUNT(X) ) OVER (PARTITION BY GROUPING(X)) * 100 || '%' AS RATIO 
  FROM R GROUP BY ROLLUP(X)

 


by 좋구만 [2016.04.01 10:04:00]

좋은거 배우고 갑니다 ㅎㅎ

댓글등록
SQL문을 포맷에 맞게(깔끔하게) 등록하려면 code() 버튼을 클릭하여 작성 하시면 됩니다.
로그인 사용자만 댓글을 작성 할 수 있습니다. 로그인, 회원가입