在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;
substr(字符串,截取开始位置,截取长度) //返回截取的字
substr('Hello World',0,1) //返回结果为 'H' *从字符串第一个字符开始截取长度为1的字符串
substr('Hello World',1,1) //返回结果为 'H' *0和1都是表示截取的开始位置为第一个字符
此处截取百分数的字符串(即去掉百分号),然后求平局值。在页面显示的时候在数字末尾加上百分号即可。