数据库

 首页 > 数据库 > Oracle > oracle中group by的高级用法

oracle中group by的高级用法

分享到:
【字体:
导读:
         摘要:oracle中groupby的高级用法简单的groupby用法selectc1,sum(c2)fromt1wheret1<>'test'groupbyc1havingsum(c2)>100;www.2cto.comrollup(多列)——上卷汇总...

oracle中group by的高级用法

oracle中group by的高级用法
 
简单的group by用法
select c1,sum(c2)
from t1
where t1<>'test'
group by c1
having sum(c2)>100;
  www.2cto.com  
rollup(多列)——上卷汇总,从最后一个汇总字段开始上卷汇总,一直到合计
select c1,c2,sum(c3)
from t1
group by rollup(c1,c2)
含义:
c1,c2分组合计
c1分组合计
总计
 
cube(多列)——组合汇总,以汇总字段的子集作为汇总条件汇总,包括合计
select c1,c2,sum(c3)
from t1
group by cube(c1,c2)
含义:
c1,c2分组合计
c1分组合计
c2分组合计
总计
 
grouping(单列名)只用于rollup和cube,单列名是rollup和cube中的一个列名,表示此记录的分组条件是否包含此列,1表示否,0表示是。
select decode(grouping(c1),1,'all c1',c1) as first,
decode(grouping(c2),1,'all c2',c2) as second,sum(c3)
from t1
group by cube(c1,c2)
含义:
使记录含义更清晰,而不是单纯的一个null值。
 
grouping sets(多列)——分列汇总,按参数中的各列分别汇总。
select c1,c2,sum(c3)
from t1
group by grouping sets(c1,c2)
含义:  www.2cto.com  
按c1和c2的分别作为group by的条件
 
grouping_id(多列)
是grouping()的扩展,相当于grouping_id(c1,c2)=(grouping(c1)||grouping(c2)表示的二进制)的值
可以表示分组的层级
 
group by语句可以同时使用普通列、rollup()和cube()等作为条件,如果一个列在不同地方出现了多次,结果集可以会重复。同时使用的含义是:普通列加上高级函数的每个结果作为group by的条件汇总,
 
group_id()函数,无参数,可以表示此分组记录是否重复,0表示第一次,1表示重复。
 
 
 
作者 hulubo
oracle中group by的高级用法
分享到:
Oracle分区表学习
Oracle分区表学习 Sql代码      -- Create table(创建分区表)      create table BILL_MONTHFEE_ZERO   (  www.2cto.com     SERV_ID       NUMBER(20) not null,   BILLING_CYCLE_MONTH NUMBER(6) not null,   DATE_TYPE      NUMBER(1),   ACC_NBR       VARCHAR2(80)   )   partition...
oracle同义词详解
oracle同义词详解 在Oracle中对用户的管理是使用权限的方式来管理的,也就是说,如果我们想使用数据库,我们就必须得有权限,但是如果是别人将权限授予了我们, 我们也是能对数据库进行操作的,但是我们必须要已授权的表的名称前键入该表所有者的名称,所以这就是比较麻烦的,遇到这种情况,我们该怎么办呢?创建个 Oracl...
  •         php迷,一个php技术的分享社区,专属您自己的技术摘抄本、收藏夹。
  • 在这里……