씨네
공부하는 개발자 강씨네
씨네
  • 분류 전체보기 (460)
    • Web (21)
      • HTML (11)
      • CSS (10)
    • JS 관련 (49)
      • JavaScript (27)
      • JQuery (22)
    • TS 관련 (15)
      • TypeScript (15)
    • NodeJS (7)
      • NodeJS (7)
    • 따라하며 배우는 시리즈 (23)
      • NodeJS & ReactJS Basic (23)
      • NodeJS & ReactJS Movie (0)
      • NodeJS & ReactJS Youtube (0)
      • NodeJS & ReactJS ChatBot (0)
    • SPA (14)
      • React (14)
      • Vue (0)
      • Anguler (0)
    • Java 관련 (118)
      • Java (52)
      • JDBC (6)
      • JSP & Servlet (18)
      • Spring Legecy (38)
      • SpringBoot (4)
    • Python (26)
      • Python (20)
      • PyMongo (1)
      • Django (5)
    • Git (24)
      • Github (24)
    • RDB (22)
      • Oracle (21)
      • MySQL (1)
    • NoSQL (5)
      • MongoDB (5)
    • OS (4)
      • Linux (4)
    • 빅데이터 (2)
      • hadoop (2)
    • IDE (20)
      • eclipse (11)
      • VSCODE (4)
      • VisualStudio (1)
      • IntelliJ (1)
      • PyCharm (1)
      • DBeaver (2)
    • Install (3)
      • Tomcat (1)
      • Docker (1)
      • Anaconda (1)
    • 오류&에러 (28)
      • TS (2)
      • NodeJS (7)
      • SQL (8)
      • Java (1)
      • Spring (4)
      • Git (6)
      • 기타 (0)
    • 알고리즘 (67)
      • 수열 (1)
      • 백준(backjoon) (39)
      • Programmers (27)
    • 자격증 (5)
      • SQLD (5)
    • 기타 (2)
    • IT유튜브로 지식쌓기 (2)

공지사항

인기 글

최근 글

티스토리

250x250
hELLO · Designed By 정상우.
씨네

공부하는 개발자 강씨네

[ORACLE] 그룹함수 - ROLLUP, CUBE, GROUPING SET
RDB/Oracle

[ORACLE] 그룹함수 - ROLLUP, CUBE, GROUPING SET

2022. 1. 1. 09:28
728x90

그룹함수

그룹함수에 조건문을 줄 때는 WHERE이 아닌 HAVING을 사용합니다.

WHERE과 HAVING의 차이는 그룹함수가 있고 없고 차이입니다.

​

--Q) 부서별 월급 합계를 구하자.(단, 월급의 합계가 7000 이상인 부서만 출력하자.)

SELECT DEPTNO, SUM(SAL) FROM EMP
HAVING SUM(SAL) >= 7000
GROUP BY DEPTNO;

​

​

1. ROLLUP

ROLLUP은 순차적으로 중간 합계를 출력합니다.

ROLLUP함수 안 컬럼의 순서가 바뀌면 결과도 바뀌게 됩니다.

​

ROLLUP의 출력 순서

​

--EX)
SELECT A, B, COUNT(*) FROM TMP GROUP BY ROLLUP(A,B);
A, B, COUNT(*)
UNION ALL
A, NULL, COUNT(8)
UNION ALL
NULL, NULL, COUNT(*)

--A컬럼, B컬럼에 대한 카운트 / A컬럼에 대한 카운트 / 전체 카운트

​

--Q) 직업, 부서 별 월급의 합을 출력하자.

SELECT JOB, DEPTNO, SUM(SAL)
FROM EMP
GROUP BY ROLLUP(JOB, DEPTNO);

​

​

2. CUBE

CUBE는 모든 중간합께를 출력합니다.

​

CUBE의 출력 순서

SELECT A,B,COUNT(*) FROM TMP GROUP BY CUBE(A,B);
NULL, NULL, COUNT(*)
UNION ALL
NULL, B, COUNT(*)
UNION ALL
A, NULL, COUNT(*)
UNION ALL
A, B, COUNT(*)

--Q) 직업, 부서 별 월급의 합을 출력하자.(위와 같은 문제)

SELECT JOB, DEPTNO, SUM(SAL)
FROM EMP
GROUP BY CUBE(JOB, DEPTNO);

​

​

3. GROUPING SET

GROUPING SET은 원하는 결과를 출력하기 위한 셋팅입니다.

​

--Q) 직업, 부서 별 월급의 합을 출력하자.(위와 같은 문제)

SELECT JOB, DEPTNO, SUM(SAL)
FROM EMP 
GROUP BY GROUPING SETS(ROLLUP(JOB,DEPTNO), DEPTNO);

​

​

​

 
728x90

'RDB > Oracle' 카테고리의 다른 글

[ORACLE] Top N Query(ROWID / ROWNUM)  (0) 2022.01.03
[ORACLE] 정렬 - ORDER BY  (0) 2022.01.02
[ORACLE] UNION, UNION ALL, INTERSECT, MINUS  (0) 2021.12.31
[ORACLE] 집계함수 - COUNT, MAX, MIN, SUM, AVG  (1) 2021.12.30
[ORACLE] 기타 함수 - NVL, DECODE, CASE [WHEN ... THEN ...] END  (0) 2021.12.29
    'RDB/Oracle' 카테고리의 다른 글
    • [ORACLE] Top N Query(ROWID / ROWNUM)
    • [ORACLE] 정렬 - ORDER BY
    • [ORACLE] UNION, UNION ALL, INTERSECT, MINUS
    • [ORACLE] 집계함수 - COUNT, MAX, MIN, SUM, AVG
    씨네
    씨네
    개발자 씨네가 공부하는 내용을 기록 겸 공유하는 블로그입니다!

    티스토리툴바