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执行路径:
结论:最终类型将会是v2类型
例子中带了一个知识点,date可以隐式转换成number类型,反之则不行。
date如果要手工转成number则比较复杂,可以用to_char(sysdate, 'fm....')转成字符,再to_number('2013-01-01', '9999G99G99', 'nls_numeric_characters=,-')