What is the Oracle equivalent of SQL Server's IsNull() function?

后端 未结 4 1636
醉话见心
醉话见心 2020-11-28 11:00

In SQL Server we can type IsNull() to determine if a field is null. Is there an equivalent function in PL/SQL?

相关标签:
4条回答
  • 2020-11-28 11:20

    coalesce is supported in both Oracle and SQL Server and serves essentially the same function as nvl and isnull. (There are some important differences, coalesce can take an arbitrary number of arguments, and returns the first non-null one. The return type for isnull matches the type of the first argument, that is not true for coalesce, at least on SQL Server.)

    0 讨论(0)
  • 2020-11-28 11:20

    Instead of ISNULL(), use NVL().

    T-SQL:

    SELECT ISNULL(SomeNullableField, 'If null, this value') FROM SomeTable
    

    PL/SQL:

    SELECT NVL(SomeNullableField, 'If null, this value') FROM SomeTable
    
    0 讨论(0)
  • 2020-11-28 11:20

    You can use the condition if x is not null then.... It's not a function. There's also the NVL() function, a good example of usage here: NVL function ref.

    0 讨论(0)
  • 2020-11-28 11:23

    Also use NVL2 as below if you want to return other value from the field_to_check:

    NVL2( field_to_check, value_if_NOT_null, value_if_null )
    

    Usage: ORACLE/PLSQL: NVL2 FUNCTION

    0 讨论(0)
提交回复
热议问题