分组聚集
查询药品和诊疗项目的平均价格和数量
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为假,返回值一定有一行数据,但是为空