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

来源:互联网 发布:数据分析师职业前景 编辑:程序博客网 时间:2024/05/08 08:08

在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都是表示截取的开始位置为第一个字符

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

0 0
原创粉丝点击