Oracle分组小计、总计示例(grouping sets的使用)

时间:2023-12-11 20:15:20

1.首先创建一个表

  1. create table TE
  2. (
  3. ID        VARCHAR2(2),
  4. T_CODE    VARCHAR2(4),
  5. T_NAME    VARCHAR2(4),
  6. T_AMOUNT  INTEGER,
  7. T_DEPT    VARCHAR2(4),
  8. T_PROJECT VARCHAR2(4),
  9. T_TYPE    VARCHAR2(1)
  10. )

2.录入数据如下:

  1. insert into te (ID, T_CODE, T_NAME, T_AMOUNT, T_DEPT, T_PROJECT, T_TYPE)
  2. values ('1', '1', '1', 10, '总部', '90', '0');
  3. insert into te (ID, T_CODE, T_NAME, T_AMOUNT, T_DEPT, T_PROJECT, T_TYPE)
  4. values ('2', '2', '2', 20, '总部', '70', '0');
  5. insert into te (ID, T_CODE, T_NAME, T_AMOUNT, T_DEPT, T_PROJECT, T_TYPE)
  6. values ('3', '3', '3', 30, '分1', '60', '0');
  7. insert into te (ID, T_CODE, T_NAME, T_AMOUNT, T_DEPT, T_PROJECT, T_TYPE)
  8. values ('4', '4', '4', 40, '分1', '50', '0');
  9. insert into te (ID, T_CODE, T_NAME, T_AMOUNT, T_DEPT, T_PROJECT, T_TYPE)
  10. values ('5', '5', '5', 50, '分2', '40', '0');
  11. insert into te (ID, T_CODE, T_NAME, T_AMOUNT, T_DEPT, T_PROJECT, T_TYPE)
  12. values ('6', '6', '6', 60, '分2', '30', '0');

3.查询全表查看

    1. select * from te;

    Oracle分组小计、总计示例(grouping sets的使用)

    4.用t.t_dept, t.t_project进行分组查询

  1. select t.t_dept, t.t_project, sum(t.t_amount) from te t
  2. group by t.t_dept, t.t_project;

结果如下:

Oracle分组小计、总计示例(grouping sets的使用)

5.用t.t_dept, t.t_project,并使用t.t_dept来做小计

  1. select t.t_dept, t.t_project, sum(t.t_amount) from te t
  2. group by grouping sets ((t.t_dept, t.t_project), t.t_dept);

结果如下: 
Oracle分组小计、总计示例(grouping sets的使用)

6.用t.t_dept, t.t_project,并使用t.t_dept来做小计,并做一次总计

  1. select t.t_dept, t.t_project, sum(t.t_amount) from te t
  2. group by grouping sets ((t.t_dept, t.t_project), t.t_dept, null);

结果如下:

Oracle分组小计、总计示例(grouping sets的使用)

7.使用grouping(字段)

  1. select grouping(t.t_dept),t.t_dept, t.t_project, sum(t.t_amount) from te t
  2. group by grouping sets ((t.t_dept, t.t_project), t.t_dept, null);

结果如下:

Oracle分组小计、总计示例(grouping sets的使用)

注意: 在存储过程中null不会正确执行 需要改成()