zoukankan      html  css  js  c++  java
  • 【Oracle】rollup函数

    当我们在做报表统计的时候,很多时候需要用到‘合计’这个功能,比如我们想得到如下格式的报表:


    这张表是按照deptno分组,然后按照deptno分组合计。rollup函数可以完美的解决这个问题。

    1.建立一张t表:

    create table T
    
    (
    
      empno  NUMBER(4),
    
      ename  VARCHAR2(10),
    
      job    VARCHAR2(9),
    
      sal    NUMBER(7,2),
    
      comm   NUMBER(7,2),
    
      deptno NUMBER(2)
    
    );

    2.插入数据:

    insert into t (EMPNO, ENAME, JOB, SAL, COMM, DEPTNO)
    
    values (7844, 'TURNER', 'SALESMAN', 1500.00, 0.00, 30);
    
     
    
    insert into t (EMPNO, ENAME, JOB, SAL, COMM, DEPTNO)
    
    values (7499, 'ALLEN', 'SALESMAN', 1600.00, 300.00, 30);
    
     
    
    insert into t (EMPNO, ENAME, JOB, SAL, COMM, DEPTNO)
    
    values (7521, 'WARD', 'SALESMAN', 1250.00, 500.00, 30);
    
     
    
    insert into t (EMPNO, ENAME, JOB, SAL, COMM, DEPTNO)
    
    values (7566, 'JONES', 'MANAGER', 2975.00, 100.00, 20);
    
     
    
    insert into t (EMPNO, ENAME, JOB, SAL, COMM, DEPTNO)
    
    values (7654, 'MARTIN', 'SALESMAN', 1250.00, 1400.00, 30);
    
     
    
    insert into t (EMPNO, ENAME, JOB, SAL, COMM, DEPTNO)
    
    values (7698, 'BLAKE', 'MANAGER', 2850.00, 100.00, 30);
    
     
    
    insert into t (EMPNO, ENAME, JOB, SAL, COMM, DEPTNO)
    
    values (7782, 'CLARK', 'MANAGER', 2450.00, 100.00, 10);
    
     
    
    insert into t (EMPNO, ENAME, JOB, SAL, COMM, DEPTNO)
    
    values (7788, 'SCOTT', 'ANALYST', 3000.00, 100.00, 20);
    
     
    
    insert into t (EMPNO, ENAME, JOB, SAL, COMM, DEPTNO)
    
    values (7839, 'KING', 'PRESIDENT', 5000.00, 100.00, 10);
    
     
    
    insert into t (EMPNO, ENAME, JOB, SAL, COMM, DEPTNO)
    
    values (7876, 'ADAMS', 'CLERK', 1100.00, 100.00, 20);
    
     
    
    insert into t (EMPNO, ENAME, JOB, SAL, COMM, DEPTNO)
    
    values (7900, 'JAMES', 'CLERK', 950.00, 100.00, 30);
    
     
    
    insert into t (EMPNO, ENAME, JOB, SAL, COMM, DEPTNO)
    
    values (7902, 'FORD', 'ANALYST', 3000.00, 100.00, 20);
    
     
    
    insert into t (EMPNO, ENAME, JOB, SAL, COMM, DEPTNO)
    
    values (7934, 'MILLER', 'CLERK', 1300.00, 100.00, 10);
    
    commit;

    3.使用rollup函数

    select empno, ename, sum(sal) as sal, sum(comm) as comm, deptno
    
    from t
    
    group by rollup(deptno, (empno, ename))
    
    having grouping(deptno) = 0;



    The End!

  • 相关阅读:
    HDU 1202 The calculation of GPA
    HDU 1201 18岁生日
    HDU 1200 To and Pro
    C语言实现的图的深度搜索与广度搜索程序
    深度优先搜索和广度优先搜索的深入讨论
    Linux sftp 安全文件传输命令
    看白鹿原有感
    中国人民抗日战争暨世界反法西斯战争胜利70周年(20150903)
    高一的我曾对自己说"要放慢脚步去生活"!?
    网络营销(续)
  • 原文地址:https://www.cnblogs.com/NextAction/p/7366602.html
Copyright © 2011-2022 走看看