[Oracle] rollup 쿼리 , 오라클 부분합 구하기 

Summary: in this tutorial, you will learn how to use the Oracle ROLLUP extension to generate reports that contain subtotals and totals.

Getting started with Oracle ROLLUP

Consider the following orders and order_items tables in the sample database:

orders and order_items tables

The following query returns the sales revenue by customers in the year of 2017. It calculates net values for the sales orders with the Shipped status and is in charge of a salesman.

 
SELECT customer_id, SUM(quantity * unit_price) amount FROM orders INNER JOIN order_items USING (order_id) WHERE status = 'Shipped' AND salesman_id IS NOT NULL AND EXTRACT(YEAR FROM order_date) = 2017 GROUP BY customer_id ORDER BY amount DESC;

Code language: SQL (Structured Query Language) (sql)

Oracle ROLLUP - GROUP By clause

To get the sum of the values in the amount column, you may come up with the following subquery:

 
SELECT SUM(amount) FROM ( SELECT customer_id, SUM(quantity * unit_price) amount FROM orders INNER JOIN order_items USING (order_id) WHERE status = 'Shipped' AND salesman_id IS NOT NULL AND EXTRACT(YEAR FROM order_date) = 2017 GROUP BY customer_id );

Code language: SQL (Structured Query Language) (sql)

oracle rollup - using subquery

Oracle provides a better and faster way to calculate the grand total by using the ROLLUP as shown in the following query:

 
SELECT customer_id, SUM(quantity * unit_price) amount FROM orders INNER JOIN order_items USING (order_id) WHERE status = 'Shipped' AND salesman_id IS NOT NULL AND EXTRACT(YEAR FROM order_date) = 2017 GROUP BY ROLLUP(customer_id);

Code language: SQL (Structured Query Language) (sql)

Oracle ROLLUP example

In this query, we used the ROLLUP expression to calculate the grand total of sales amounts of the selected orders.

As shown clearly from the output, the row with a NULL value in the customer_id column denotes the grand total row. The amount column of the grand total row showed the sum of all amounts in the output.

Oracle ROLLUP syntax

The ROLLUP is an extension of the GROUP BY clause. The ROLLUP calculates multiple levels of subtotals across a group of columns (or dimensions) along with the grand total.

The following illustrates the syntax of the ROLLUP :

 
SELECT col1, col2, aggregate(col3) FROM table_name GROUP BY ROLLUP (col1, col2);

Code language: SQL (Structured Query Language) (sql)

In the query syntax above, the ROLLUP creates subtotals that roll up from the most detailed level to a grand total, following a grouping column specified in the ROLLUP.

The ROLLUP works as follows:

  1. First, calculate the standard aggregate values in the GROUP BY clause.
  2. Then, progressively create higher-level subtotals of the grouping columns, which are col2 and col1 columns, from right to left.
  3. Finally, calculate the grand total.

The ROLLUP clause generates the number of grouping sets which is the same as the number grouping columns specified in the ROLLUP plus a grand total. In other words, if you have n columns listed in the ROLLUP, you will get n+ 1 level of subtotals with ROLLUP.

경축! 아무것도 안하여 에스천사게임즈가 새로운 모습으로 재오픈 하였습니다.
어린이용이며, 설치가 필요없는 브라우저 게임입니다.
https://s1004games.com

In the syntax above, the ROLLUP clause generates the following grouping sets:

  1. (col1, col2)
  2. (col2)
  3. (grand total)

The number of rows in the output is derived from the number of unique combinations of values in the grouping columns.

To reduce the number of subtotals, you can perform a partial roll up as shown in the following syntax:

 
SELECT col1, col2, aggregate(col3) FROM table_name GROUP BY col1, ROLLUP (col2);

Code language: SQL (Structured Query Language) (sql)

More Oracle ROLLUP examples

The following example use ROLLUP to return the sales values by salesman and customer:

 
SELECT salesman_id, customer_id, SUM(quantity * unit_price) amount FROM orders INNER JOIN order_items USING (order_id) WHERE status = 'Shipped' AND salesman_id IS NOT NULL AND EXTRACT(YEAR FROM order_date) = 2017 GROUP BY ROLLUP(salesman_id,customer_id);

Code language: SQL (Structured Query Language) (sql)

Oracle ROLLUP multiple columns example

As you can see from the output, the query returned the following set of rows:

  • The regular aggregation rows that would be returned by the GROUP BY clause without using the ROLLUP expression.
  • The first-level of subtotals aggregating across salesman for each combination of salesman and customer.
  • The second-level subtotals aggregating across salesman and customer for each salesman.
  • A grand total row.

The following query performs a partial rollup:

 
SELECT salesman_id, customer_id, SUM(quantity * unit_price) amount FROM orders INNER JOIN order_items USING (order_id) WHERE status = 'Shipped' AND salesman_id IS NOT NULL AND EXTRACT(YEAR FROM order_date) = 2017 GROUP BY salesman_id, ROLLUP(customer_id);

Code language: SQL (Structured Query Language) (sql)

Oracle ROLLUP partial roll up

The query outputs regular aggregation rows that would be returned by the GROUP BY clause without using the ROLLUP and the subtotals aggregating across salesman for each combination of salesman and customer.

In this tutorial, you have learned how to use the Oracle ROLLUP to generate reports that contain subtotals and totals.

 

[출처] https://www.oracletutorial.com/oracle-basics/oracle-rollup/

 

 

본 웹사이트는 광고를 포함하고 있습니다.
광고 클릭에서 발생하는 수익금은 모두 웹사이트 서버의 유지 및 관리, 그리고 기술 콘텐츠 향상을 위해 쓰여집니다.
번호 제목 글쓴이 날짜 조회 수
공지 오라클 기본 샘플 데이터베이스 졸리운_곰 2014.01.02 28517
공지 [SQL컨셉] 서적 "SQL컨셉"의 샘플 데이타 베이스 SAMPLE DATABASE of ORACLE 가을의 곰을... 2013.02.10 28315
공지 [G_SQL] Sample Database 가을의 곰을... 2012.05.20 35388
982 [데이터베이스 모델링] 관계형 데이터 모델링 하향식과 상향식 졸리운_곰 2022.05.07 371
981 [기본 SQL] SELECT, INSERT, UPDATE, DELETE file 졸리운_곰 2022.04.26 331
980 [데이터베이스 모델링] 모델링 IE 표기법 (까치발, 까마귀발, crow-feet) file 졸리운_곰 2022.04.26 1011
979 [stat(통계) R 언어] 유명하고 많이 사용하는 R 패키지 정리 졸리운_곰 2022.04.19 243
978 [빅데이터분석기사 실기] 빅데이터분석기사 3회 실기 문제 복원 (기출) + 시험공부 팁 file 졸리운_곰 2022.02.07 285
977 [빅데이터분석기사] 빅데이터분석기사 노트정리 공유 file 졸리운_곰 2022.02.07 1992
976 [SQL 데이터분석 학습][오라클][Oracle] 도커로 Oracle 간단 설치하기 file 졸리운_곰 2022.02.06 225
975 [빅데이터분석기사] 실기 : 시험 후기, [자격증] 빅데이터분석기사 실기 합격 후기 (비전공자 문과) file 졸리운_곰 2022.02.04 342
974 [R 데이터 분석] anaconda에서 R 사용하기 file 졸리운_곰 2022.01.16 282
973 [R 데이터 분석] Using C/C++ in R , R언어에서 C/C++ 사용하기 졸리운_곰 2021.11.21 358
972 암호화폐 (비트코인, cryptocurrency, bitcoin) [Ethereum] Remix 를 이용하여 이더리움 솔리디티(Solidity) 개발 연습 하기! file 졸리운_곰 2021.10.19 310
971 암호화폐 (비트코인, cryptocurrency, bitcoin) [Ethereum] Remix IDE를 이용한 Solidity 프로그래밍 file 졸리운_곰 2021.10.17 305
970 [오라클][Oracle] ORA-00904: 부적합한 식별자 졸리운_곰 2021.10.13 307
969 [오라클][Oracle] 대소문자 구분 없이 검색하는 경우에 WHERE 조건 file 졸리운_곰 2021.10.13 401
968 [오라클, Oracle] 오라클 비밀번호 만료(Oracle password has expired) file 졸리운_곰 2021.10.10 341
967 암호화폐 (비트코인, cryptocurrency, bitcoin) [Ethereum] 스마트 컨트렉트로 "Hello, World"를 출력하자.​ file 졸리운_곰 2021.10.09 334
966 [데이터분석][데이터수집 전처리] MS 엑셀(Excel)에서 UTF-8 로 된 csv 파일 가져오기 file 졸리운_곰 2021.09.30 489
965 [MySQL] 관리자 root , admin 계정 추가 : MySQL 관리자 계정 추가 졸리운_곰 2021.09.26 1234
964 [MySQL] mysql 에서 컬럼과 로우 바꾸기, 행과 열 바꾸기 How to Transpose Rows to Columns Dynamically in MySQL file 졸리운_곰 2021.09.13 211
» [Oracle] rollup 쿼리 , 오라클 부분합 구하기 file 졸리운_곰 2021.09.01 510
대표 김성준 주소 : 경기 용인 분당수지 U타워 등록번호 : 142-07-27414
통신판매업 신고 : 제2012-용인수지-0185호 출판업 신고 : 수지구청 제 123호 개인정보보호최고책임자 : 김성준 sjkim70@stechstar.com
대표전화 : 010-4589-2193 [fax] 02-6280-1294 COPYRIGHT(C) stechstar.com ALL RIGHTS RESERVED