• pl/sqlcoalesce/nvl


    -- Select the first one which is not null:
    example:
    SQL
    > select coalesce(null,null,2from dual;
    COALESCE(NULL,NULL,2)
    ---------------------
                        2 

    -- Two parameters are only required here:
    select nvl(1nullfrom dual;

    -- If equivalent then null else return the first param 
    select nullif(2,2from dual; 


    The following three sections are equivalent:


    -- One, notice the difference between CASE statement and CASE expression
    SET SERVEROUTPUT ON
    DECLARE
        v_num1 
    NUMBER := &sv_num1;
        v_num2 
    NUMBER := &sv_num2;
        v_num3 
    NUMBER := &sv_num3;
        v_result 
    NUMBER;
    BEGIN
        v_result :
    = CASE
                
    WHEN v_num1 IS NOT NULL THEN v_num1
                
    ELSE    
                    
    CASE
                        
    WHEN v_num2 IS NOT NULL THEN v_num2
                        
    ELSE v_num3
                    
    END
                
    END;
        DBMS_OUTPUT.PUT_LINE (
    'Result: '||v_result);
    END
     
    -- Two
    CASE
        
    WHEN v_num1 IS NOT NULL THEN v_num1
        
    WHEN v_num2 IS NOT NULL THEN v_num2
        
    ELSE v_num3
    END

    -- Three
    CASE
        
    WHEN v_num1 IS NOT NULL THEN v_num1
        
    ELSE COALESCE(v_num2, v_num3)
    END
  • 相关阅读:
    python闯关_Day012
    python闯关_Day010
    python闯关_Day009
    python闯关_Day008
    python闯关_Day07
    什么是PRD、MRD与BRD?
    Python中logging日志使用
    git一些常用的命令
    Python第三方库
    FastDFS分布式存储服务器安装
  • 原文地址:https://www.cnblogs.com/kelin1314/p/1920846.html
Copyright © 2020-2023  润新知