Oracle函数NULLIF

1、NULLIF函数

  函数语法:NULLIF(Expression1,Expression2)

  函数功能:如果来个表达式相等,则返回NULL值,否则返回第一个表达式

功能很简单,但是要注意以下几种情况:

1)两个表达式的类型必须相等。

SQL> SELECT nullif(100, 'a') FROM dual;
SELECT nullif(100, 'a') FROM dual
                   *
ERROR at line 1:
ORA-00932: inconsistent datatypes: expected NUMBER got CHAR

以下这样也会报错,是不会有隐式转换的

SELECT nullif('100', 1) FROM dual;

2)有NULL的情况比较特殊

SELECT nullif(NULL, NULL) FROM dual;
SELECT nullif(NULL, 100) FROM dual;
SELECT nullif(100, NULL) FROM dual;

只有第三句可以成功执行,返回100,也就是第一个参数不能是NULL,但是第二个可以

SQL> SELECT nullif(100, NULL) FROM dual;

NULLIF(100,NULL)
----------------
             100

2、COALESCE函数

函数语法:COALESCE(Expression1,Expression2,Expression3,......)

函数功能:参数可以是值或表达式,返回以第一个非NULL的参数值
SQL> select coalesce(100,null,200) from dual;

COALESCE(100,NULL,200)
----------------------
                   100

SQL> select coalesce(null,50,200) from dual;

COALESCE(NULL,50,200)
---------------------
                   50

同样的,参数的类型必须相同

SQL> select coalesce(null,1,'A01') FROM DUAL;
select coalesce(null,1,'A01') FROM DUAL
                       *
ERROR at line 1:
ORA-00932: inconsistent datatypes: expected NUMBER got CHAR

posted on 2022-11-23 17:42  小yq  阅读(1339)  评论(0编辑  收藏  举报

导航