oracle常用函数 (二)

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值