oracle百分数的统计(计算百分数的平均数)

本文介绍了一种在Oracle数据库中处理包含百分号的百分数字段的方法。通过使用substr和length函数去除百分号,并计算平均值。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在oracle中,百分数一般使用varchar2的类型来表示,刚开始计算百分数的时候,我想用to_number函数将类型转换为number,oracle报错:不是数字。

突然明白,百分数后面有百分号,在oracle中确实不是数字。在网上查到了方法:

select data_type,
       sum(dataset_plannum) as dataset_plannum,
       sum(dataset_actunum) as dataset_actunum,
       avg(substr(data_coverage, 1, length(data_coverage) - 1)) as data_coverage,
       avg(substr(data_integrity, 1, length(data_integrity) - 1)) as data_integrity,
       avg(substr(data_accuracy, 1, length(data_accuracy) - 1)) as data_accuracy,
       sum(data_sum) as data_sum,
       sum(data_correctsum) as data_correctsum,
       sum(data_wrongsum) as data_wrongsum
  from tsys_dataquality_sum t
 group by t.data_type;



length(string)计算string所占的字符长度:返回字符串的长度,单位是字符;

substr(字符串,截取开始位置,截取长度) //返回截取的字

substr('Hello World',0,1) //返回结果为 'H'  *从字符串第一个字符开始截取长度为1的字符串

substr('Hello World',1,1) //返回结果为 'H'  *0和1都是表示截取的开始位置为第一个字符

此处截取百分数的字符串(即去掉百分号),然后求平局值。在页面显示的时候在数字末尾加上百分号即可。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值