1. SUM()求和,AVG()平均,COUNT() 计数
select id, name, sum(price)
from table_price
group by id
having sum(price)>50000
2. ROUND() 四舍五入
select *
from test_table
where round(test_num , 1) >90.6 #其中,1表示保留1位小数
3. NVL()处理空值,NULLIF()
- nvl(exp1,exp2) ,当exp1为null时,返回exp2;当exp1不为null时,返回exp1。
例: 查询门店月平均销售额,如果某月销售额为空,用0代替,避免因为sale值为空只求出11个月的平均值。
select count(*), avg(nvl(sale,0))
from table_sale
注:扩展函数nvl2(exp1,exp2,exp3),若exp1为null,返回exp3,否则返回exp2。
- nullif(exp1,exp2) ,当exp1=exp2时,返回NULL,否则返回exp1。
可用于判断除数是否为0,如果为零,则将除数赋null。 当除数为null时,表达式=0,这样就可以避免除数为0的情况。
NVL() 的目的是:如果为空,则指定一个值。
NVL2() 的目的是:如果不为空,则指定一个值;为空则指定另一个值。
NULLIF() 的目的是:如果等于某个值则按空处理。
参考:Oracle中NVL、NVL2、NULLIF 三个函数的区别? - 享受代码 - 博客园
4. COALESCE() 返回第一个不为空的表达式的值(这个表达式可以是列)
coalesce(exp1,exp2, ... , expn)
注:所有表达式必须是相同类型,或者可以隐性转换为相同的类型。
select coalesce(null,null,null,3,5)
from dual
返回结果为:3