oracle nvl2函数

时间:2022-07-26 21:04:18

nvl2(v1, v2, v3) 定义:如果v1为空,返回v3; 不为空,返回v2

nvl2要求v2,v3的类型一致,不一致会发生类型转换。问题:最终返回值类型是v2的类型还是v3的类型?

看题目:nvl2(null,sysdate-(sysdate-1/24/60), sysdate) 最终返回的是什么类型?

如果做一下实验,可能看得更明白一些:

select nvl2(1, sysdate-(sysdate-1/24/60), sysdate) from dual;
select nvl2(null,sysdate-(sysdate-1/24/60), sysdate) from dual; select nvl2(1, sysdate, sysdate-(sysdate-1/24/60) from dual;
select nvl2(null, sysdate, sysdate-(sysdate-1/24/60) from dual; select sysdate-1/24/60 from dual;

上面两条语句正确执行,中间两条语句报错:ORA-00932:数据类型不一致:应为DATE,但却获得DATE JULIAN

下面是nvl2执行路径:

oracle nvl2函数

结论:最终类型将会是v2类型

例子中带了一个知识点,date可以隐式转换成number类型,反之则不行。

date如果要手工转成number则比较复杂,可以用to_char(sysdate, 'fm....')转成字符,再to_number('2013-01-01', '9999G99G99', 'nls_numeric_characters=,-')