平均值可以用avg函数,也可以用表达式计算,具体语句如下:
select avg(t.comm) , --只计算有值的行进行平均,哪怕是个0,空值不参与计算
round(avg(nvl(t.comm, 0))), --nvl函数把空值赋值为0,所以空值的参与计算
round(sum(t.comm) / count(*)), --变通求平均值,count(*)统计所有行数,因此空值参与计算
round(sum(t.comm) / count(t.comm)), --count(字段)统计非空行数,空值不参与计算
round(sum(t.comm) / count(nvl(t.comm, 0))) --nvl函数把空值赋值为0,所以空值的参与计算
from EMP t
运行结果如下: