【oracle】DECODE ,NVL,NVL2的用法
来源:互联网 发布:椭圆曲线密码算法属于 编辑:程序博客网 时间:2024/05/18 02:20
Decode
DECODE的语法:DECODE(value,if1,then1,if2,then2,if3,then3,...,else),表示如果value 等于if1时,DECODE函数的结果返回then1,...,如果不等于任何一个if值,则返回else。初看一下,DECODE 只能做等于测试,但刚才也看到了,我们通过一些函数或计算替代value,是可以使DECODE函数具备大于、小于或等于功能。
NVL
1.NVL ( )语法:nvl(expr1,expr2)
如果 expr1 是 null 值,则 nvl 函数返回 expr2 ,否则就返回 expr1 。
说明:参数 expr1、expr2 可以是任何数据类型,但应该保持相同。若两者数据类型不一致,则Oracle数据库会隐式的转换其中一个的数据类型使其保持和另一个一致,若无法转换则会返回错误。隐式转换的实施规则如下:
(1)若 expr1 是字符数据,则Oracle数据库在比较之前就会把 expr2 转换成 expr1 的数据类型并且返回 VARCHAR2 数据类型到 expr1 的字符集。
(2) 若 expr1 是数值型,则Oracle数据库决定哪个参数具有最高数值优先级,并把另一个参数的数据类型隐式转换成这种数据类型,并返回这种数据类型的数据。
实例:返回员工姓名和奖金,若该员工没有奖金则返回 Not Applicable
SELECT last_name, NVL(TO_CHAR(commission_pct), 'Not Applicable') "COMMISSION"
FROM employees
WHERE last_name LIKE 'B%'
ORDER BY last_name;
NVL2
语法:nvl2(expr1,expr2,expr3)
如果 expr1 不是 null 值,则 nvl 函数返回 expr2 ,否则就返回 expr3 。参数可以返回任何数据类型的值,但是 expr2 和 expr3 不能是 LONG 型的数据类型。
说明:若 expr2 和 expr3 的数据类型不同:
(1)若 expr2 是字符数据,则Oracle数据库在比较之前就会把 expr3 转换成 expr2 的数据类型除非 expr3 是null。在 这种情况下,隐式数据转换是不必要的。Oracle数据库返回 VARCHAR2 数据类型到 expr2 的字符集。
(2) 若 expr2 是数值型,则Oracle数据库决定哪个参数具有最高数值优先级,并把另一个参数的数据类型隐式转换成这种数据类型,并返回这种数据类型的数据。
实例:返回员工收入,看员工收入(income)是否由工资(salary)加奖金(commission)组成,这取决于commission_pct列是否为null
SELECT last_name, salary, NVL2(commission_pct, salary + (salary * commission_pct), salary) income FROM employees
WHERE last_name like 'B%'
ORDER BY last_name;
- 【oracle】DECODE ,NVL,NVL2的用法
- oracle中的nvl 、nvl2、decode、case when 函数的用法
- Oracle中NVL、NVL2、DECODE函数的用法
- oracle decode nvl nvl2 sign(即sin) 函数用法
- Oracle nvl(),nvl2()函数的用法
- Oracle 中 nvl、nvl2、nullif、coalesce、decode 函数的用法详解
- Oracle 中 nvl、nvl2、nullif、coalesce、decode 函数的用法详解
- Mysql中ifNull()/if()/case when用法和Oracle中nvl()/nvl2()/decode()的用法及其比较
- oracle的nvl和nvl2
- oralce:nvl nvl2 decode
- oracle NVL、NVL2,、NULLIF、COALESCE函数的用法
- oracle NVL、NVL2,、NULLIF、COALESCE函数的用法
- oracle中的NVL和NVL2及NULLIF再及decode函数用法总结
- oracle一些重要函数:nvl, nvl2, nullif,COALESCE,decode,case
- NVL NVL2 NULLIF DECODE CASE
- oracle nvl和nvl2的区别
- oracle的nvl和nvl2函数
- ORACLE中nvl,nvl2,nullif的使用
- C/C++中extern关键字详解(转)
- js 文本编辑器
- oracle基本命令
- 欢迎使用CSDN-markdown编辑器
- NavigationBar 隐藏和显示带来的问题和解决办法
- 【oracle】DECODE ,NVL,NVL2的用法
- java rsa加密密码错误
- Dll
- python实现查询mac号对应的OUI厂商信息
- iOS开发进阶 - 使用shell脚本自动打包上传到fir.im上
- 使用Gradle构建多个不同applicationId包
- js实现完美身份证号有效性验证
- xml转义符使用
- Android 性能优化之使用线程池处理异步任务