博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
oracle函数nvl,nvl2的区别,nullif函数,coalesce函数
阅读量:4673 次
发布时间:2019-06-09

本文共 900 字,大约阅读时间需要 3 分钟。

在oracle中用nvl和nvl2函数来解决为空的情况,例如,如果奖金为空,则为它指定一个数。也就是nvl(奖金字段,指定的奖金),但是两个的类型要一致。

1)nvl()函数

SQL> select comm,nvl(comm,111) from emp;如果comm为空,则将它设置为111;

2)nvl2()函数

SQL> select comm,nvl2(comm,666,555)from emp;如果comm不为空返回666,为空返回555,如果第二个参数和第三个参数类型不同,则,第三个参数会自动转为第二个参数的类型。

nvl和nvl2都可以用来处理字段为空的情况,nvl2比nvl的功能更加强大,而且nvl的两个参数类型必须一致,如果不一致则会出现错误,而nvl2的参数可以不同,如果第二个参数和第三个参数类型不同,则,第三个参数会自动转为第二个参数的类型。

nullif()函数用于判断两个字段是否相等,相同返回空值,不同返回第一个参数。

SQL> select nullif(1,1)from dual;

-----------

3)NULLIF(1,1)

SQL> select nullif(1,0)from dual;

NULLIF(1,0)

-----------
1

 4)coalesce()函数

  coalesce()函数返回第一个不为空的值,例如

SQL> select coalesce(null,1,4) from dual;

COALESCE(NULL,1,4)

------------------
1

SQL> select coalesce(null,null,4) from dual;

COALESCE(NULL,NULL,4)

---------------------
4

SQL> select coalesce(1,null,4) from dual;

COALESCE(1,NULL,4)

------------------
1

转载于:https://www.cnblogs.com/jasonboren/p/10900757.html

你可能感兴趣的文章
Source InSight context 窗口丢失的解决办法
查看>>
cut point and bridge总结
查看>>
(5)Oracle基础--约束
查看>>
【Nginx】磁盘文件写入飞地发
查看>>
默认情况下安装的应用程序C盘后提示权限不足,当你开始介意。。。
查看>>
su root 后还是不能使用useradd ,useradd 等命令
查看>>
URL.createObjectURL图片预览
查看>>
js 中exec、test、match、search、replace、split用法
查看>>
Android开发笔记(一)手势识别
查看>>
mybatis 复习笔记03
查看>>
zoj 3703(背包)
查看>>
一种新的子波域滤波算法
查看>>
cookie之三天免登录代码
查看>>
1043 幸运号码 数位DP
查看>>
js18
查看>>
2018-2019-2 20175308实验一 《Java开发环境的熟悉》实验报告
查看>>
如何设置WIN7自动登录(去除登录密码)
查看>>
关于bash中if语法结构的广泛误解(转)
查看>>
10G整数文件中寻找中位数或者第K大数
查看>>
操作手机数据库的uri
查看>>