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
    评论
Oracle 中,可以使用自定义聚合函数来实现类似于 `wm_concat` 的功能,该函数可以将多行字符串按照指定的分隔符拼接成一个 CLOB 类型的字符串,并返回该字符串。 以下是一个示例代码: ```sql CREATE OR REPLACE TYPE t_string_agg AS OBJECT ( g_string CLOB, STATIC FUNCTION ODCIAggregateInitialize(sctx IN OUT t_string_agg) RETURN NUMBER, MEMBER FUNCTION ODCIAggregateIterate(self IN OUT t_string_agg, value IN VARCHAR2) RETURN NUMBER, MEMBER FUNCTION ODCIAggregateTerminate(self IN t_string_agg, returnValue OUT CLOB, flags IN NUMBER) RETURN NUMBER, MEMBER FUNCTION ODCIAggregateMerge(self IN OUT t_string_agg, ctx2 IN t_string_agg) RETURN NUMBER ); CREATE OR REPLACE TYPE BODY t_string_agg IS STATIC FUNCTION ODCIAggregateInitialize(sctx IN OUT t_string_agg) RETURN NUMBER IS BEGIN sctx := t_string_agg(CLOB('')); RETURN ODCIConst.Success; END; MEMBER FUNCTION ODCIAggregateIterate(self IN OUT t_string_agg, value IN VARCHAR2) RETURN NUMBER IS BEGIN IF self.g_string IS NULL THEN self.g_string := value; ELSE self.g_string := self.g_string || ', ' || value; END IF; RETURN ODCIConst.Success; END; MEMBER FUNCTION ODCIAggregateTerminate(self IN t_string_agg, returnValue OUT CLOB, flags IN NUMBER) RETURN NUMBER IS BEGIN returnValue := self.g_string; RETURN ODCIConst.Success; END; MEMBER FUNCTION ODCIAggregateMerge(self IN OUT t_string_agg, ctx2 IN t_string_agg) RETURN NUMBER IS BEGIN IF self.g_string IS NULL THEN self.g_string := ctx2.g_string; ELSE self.g_string := self.g_string || ', ' || ctx2.g_string; END IF; RETURN ODCIConst.Success; END; END; CREATE OR REPLACE FUNCTION string_agg(input VARCHAR2) RETURN CLOB AGGREGATE USING t_string_agg; ``` 在上述代码中,我们定义了一个 `t_string_agg` 类型,它包含一个 CLOB 类型的字符串和四个成员函数,分别是 `ODCIAggregateInitialize`、`ODCIAggregateIterate`、`ODCIAggregateTerminate` 和 `ODCIAggregateMerge`。这四个函数的作用分别是初始化聚合函数状态、将输入值聚合到状态中、从状态中获取聚合结果并返回、合并两个状态。 然后,我们使用 `AGGREGATE USING` 子句来定义一个名为 `string_agg` 的聚合函数,该函数使用刚刚定义的 `t_string_agg` 类型实现。最后,我们可以像使用内置聚合函数一样使用 `string_agg` 函数来实现字符串拼接功能: ```sql SELECT string_agg(last_name) FROM employees; ``` 以上示例代码中,我们将 `employees` 表中的所有 `last_name` 字段的值拼接成一个 CLOB 类型的字符串。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值