博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
NVL函数(NVL,NVL2,NULLIF,COALESCE)
阅读量:5816 次
发布时间:2019-06-18

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

NVL

语法:NVL( expr1, expr2)   

功能:如果expr1为NULL,则NVL函数返回expr2的值,否则返回expr1的值,如果两个参数的都为NULL ,则返回NULL。   

注意事项:expr1和expr2必须为同一数据类型,除非显式的使用TO_CHAR函数进行类型转换。

SQL> select nvl(1,null) from dual;NVL(1,NULL)-----------          1SQL> select nvl(null,2) from dual;NVL(NULL,2)-----------          2SQL> select nvl(1,2) from dual;  NVL(1,2)----------         1SQL> select nvl(null,null) from dual;NVL(NULL,NULL)--------------SQL>

NVL2

语法:NVL2(expr1,expr2,expr3)

功能:如果参数表达式expr1值为NULL,则NVL2()函数返回参数表达式expr3的值;如果参数表达式expr1值不为NULL,则NVL2()函数返回参数表达式expr2的值。

SQL>  select nvl2(null,2,3) from dual; NVL2(NULL,2,3)--------------             3SQL>  select nvl2(1,null,3) from dual;NVL2(1,NULL,3)--------------SQL>  select nvl2(1,2,3) from dual;NVL2(1,2,3)-----------          2SQL>

NULLIF

语法:NULLIF ( expression1 , expression2 )   

参数:expression1,expression2 常量、列名、函数、子查询或算术运算符、按位运算符以及字符串运算符的任意组合。   

返回类型:返回类型与第一个 expression1 相同。   

输出结果:如果两个表达式不相等,NULLIF 返回第一个 expression1 的值。如果两个表达式相等,NULLIF 返回空值NULL。

SQL> select nullif(1,2) from dual; NULLIF(1,2) ----------- 1 SQL> select nullif(1,1) from dual; NULLIF(1,1) ----------- SQL>

COALESCE

语法:COALESCE ( expression [ ,...n ] )

参数:expression 任何类型的表达式。n表示可以指定多个表达式的占位符。所有表达式必须是相同类型,或者可以隐性转换为相同的类型。

返回类型:将相同的值作为 expression 返回。

作用:返回表达式中第一个非空表达式

注意:如果所有自变量均为 NULL,则 COALESCE 返回 NULL 值。  

COALESCE(expression1,...n) 与此 CASE 函数等价:   

CASE   WHEN (expression1 IS NOT NULL) THEN expression1   ...   

WHEN (expressionN IS NOT NULL) THEN expressionN   

ELSE NULL

SQL> select coalesce(null,null,null,2,null) from dual;COALESCE(NULL,NULL,NULL,2,NULL------------------------------                             2SQL> select coalesce(null,1,null,2,null) from dual;COALESCE(NULL,1,NULL,2,NULL)----------------------------                           1SQL> select coalesce(null,null,null,null,null) from dual;COALESCE(NULL,NULL,NULL,NULL,N------------------------------SQL>

 

转载于:https://www.cnblogs.com/rusking/p/4644792.html

你可能感兴趣的文章
一周总结
查看>>
将txt文件转化为json进行操作
查看>>
线性表4 - 数据结构和算法09
查看>>
C语言数据类型char
查看>>
Online Patching--EBS R12.2最大的改进
查看>>
Binary Search Tree Iterator leetcode
查看>>
Oracle性能优化--DBMS_PROFILER
查看>>
uva-317-找规律
查看>>
Event事件的兼容性(转)
查看>>
我的2014-相对奢侈的生活
查看>>
zoj 2412 dfs 求连通分量的个数
查看>>
Java设计模式
查看>>
一文读懂 AOP | 你想要的最全面 AOP 方法探讨
查看>>
Spring Cloud 微服务分布式链路跟踪 Sleuth 与 Zipkin
查看>>
ORM数据库框架 SQLite 常用数据库框架比较 MD
查看>>
华为OJ 名字美丽度
查看>>
微信公众号与APP微信第三方登录账号打通
查看>>
onchange()事件的应用
查看>>
Windows 下最佳的 C++ 开发的 IDE 是什么?
查看>>
软件工程师成长为架构师必备的十项技能
查看>>