oracle百分数的统计(计算百分数的平均数)
2016-12-10 09:21
302 查看
在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都是表示截取的开始位置为第一个字符
此处截取百分数的字符串(即去掉百分号),然后求平局值。在页面显示的时候在数字末尾加上百分号即可。
突然明白,百分数后面有百分号,在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都是表示截取的开始位置为第一个字符
此处截取百分数的字符串(即去掉百分号),然后求平局值。在页面显示的时候在数字末尾加上百分号即可。
相关文章推荐
- 有时候执行的oracle,sql语句要查看下性能情况,可以用这个进行下简单计算和统计
- 用Oracle写分组计算数量后再合计,并得出百分数
- oracle DB2 统计 计算从0001-01-01 到现在的天数
- oracle表示百分数,加减,统计
- Oracle计算连续天数,计算连续时间,Oracle连续天数统计
- ORACLE性能调整--统计信息的迁移
- ORACLE性能调整--统计信息的迁移(Oracle- 性能调优)
- SQLServer中的Datediff移植到ORACLE计算有误怎么解决?
- oracle分组统计
- 我能用Windows PowerShell做什么:基本统计计算
- 如何计算oracle的数据缓冲区命中率与共享池的命中率
- oracle分析函数lag/lead不能计算日期型数据?
- Oracle统计分析函数集之一(转载)
- oracle:两条sql语句实现层次查询的反序权值计算与输出
- Oracle自由范围的碎片计算
- ORACLE与MSSQL计算时间差的SQL操作
- Oracle一些日期时间的计算
- Oracle函数参考(用于计算某个数值所表示的时间)
- 全球获得Oracle认证人数最新统计
- Oracle中如何计算时间差