oracle分组聚集

分组聚集

查询药品和诊疗项目的平均价格和数量

select avg(dj),count(*)
 from hr.medi_item
group by ylxmlb;
//group by对医疗项目类别分组,分别求单价和数量

查询每个科室在2012年度发送的总费用、总报销费用和总自付费用

select ksbm,sum(zje),sum(bxje),sum(zfje)
 from he.patient_script_genl
where fyfsrq between to_date('2012.0101','yyyy.mm.dd')
 and to_date('2012.12.31','yyyy.mm.dd')
group by ksbm;
//group字段要选择唯一标识分组的,科室编码是唯一标识的

查询每个年份,不同性别的人

select count(grbm) from hr.per_natl
 where csrq is not null
group by to_char(csrq,'yyyy'),xb;

查询重名药品和该药品重名次数

select ylcmmc,count(*)
 from hr.medi_item
where ylxmlb ='1'
group by ylxmmc
having count(*)>1;
//having筛选语句

查询2012年度发生的总费用在100以上的科室编码和总费用

select ksbm,sum(zje),sum(bxje),sum(zfje)
 from hr.patient_script_genl
where fyfsrq between to_date('2012.0101','yyyy.mm.dd') //发生在2012年度的
 and to_date('2012.12.31','yyyy.mm.dd')
 group by ksbm
having sum(zje)>100; //金额大于100

分组聚集的特点
1.使用group by子句的sql语句,select子句中只能出现聚集函数和group by子句中出现的属性名
【where语句中不可出现聚集函数】
2.聚集分组与不使用聚集分组的聚集函数不同之处:如果聚集分组的输入值为空集,此时聚集函数返回空集,如果where为假,返回值一定有一行数据,但是为空

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值