oracle聚集函数

聚集函数

1.常用
平均值:avg
最小值:min
最大值:max
总和:sum
计数:count
其中sum和avg输入的必须是数值,其他运算可以作用于数据库中任何数据类型

查询诊疗项目的平均单价和数量,比较下列两个sql的返回结果

select avg(dj),count(*)
 from hr.medi_item
where ylxmlb='2';
//count一样,会把单价为0的过滤

select avg(nvl(dj,0)),count(*)
 from hr.medi_item
where ylxmlb='2';
//对单价进行空值转换,把单价为空的转换为0.所以avg不一会

查询编码是‘11111111’的病人的报销总费用和报销次数,比较下列两个sql的返回结果

select sum(bxje),count *)
 from dw.patient_settle
where grbm = '111111111';
//sum空,count0

select nvl(sum(bxje),0),count(*)
 from hr.patient_settle
where grbm='111111111';
//sum0 count0

2.聚集函数的特性

  • 1)使用聚集函数查询的结果是关系,其中只包含一个元组
  • 2)count(属性名)和count(*)的区别在于,星花返回满足条件的元组的总个数(即使一个元组的所有属性取值均为null也会计算在内),count(属性名)返回该属性中取值不为null的总个数;
  • 3)不匀速在count(*)中使用distinct
  • 4)不使用分组的聚集函数,在select子句中,只能出现聚集函数,不能出现属性名出来
  • 5)除了count(*)以外的聚集函数,均忽略null值,如果应用的需求不希望忽略null值,可以使用nvl函数进行处理
  • 6)聚集函数在输入为空集的情况下也返回一个关系,返回结果为null值,count函数例外,在输入空值,count返回0
  • 7)聚集函数只能出现在select子句和having子句中
    【having筛选子句】
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值