• oracle nvl2函数


    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=,-')

  • 相关阅读:
    CodeForces
    hdu4003 树形dp
    hdu2196
    poj2486
    hdu1502 树形dp入门题
    cf 686D
    bzoj2763 分层图
    hdu4424 并查集+贪心+思维
    poj1734 最小环+输出路径
    集训题解1
  • 原文地址:https://www.cnblogs.com/hyang0/p/10633820.html
Copyright © 2020-2023  润新知