Ricerca…


Sintassi

  • CREATE [OR REPLACE] FUNCTION nome_funzione [(parametro [, parametro])]

    RETURN return_datatype

    IS | COME

    [Declaration_section]

    BEGIN eseguibile_selezione

    [EXCEPTION exception_section]

    FINE [nome_funzione];

Genera GUID

Create Or Replace Function Generateguid
Return Char Is
    V_Guid Char(40);
Begin
    Select Substr(Sys_Guid(),1,8)||'-'||Substr(Sys_Guid(),9,4)||'-'
                        ||Substr(Sys_Guid(),13,4)||'-'||Substr(Sys_Guid(),17,4)||'-'
                        ||Substr(Sys_Guid(),21) Into V_Guid 
                        From Dual;
    Return V_Guid;
Exception
    When Others Then
    dbms_output.put_line('Error '|| SQLERRM);
End Generateguid;

Funzioni di chiamata

Esistono alcuni modi per utilizzare le funzioni.

Chiamare una funzione con una dichiarazione di assegnazione

DECLARE
    x NUMBER := functionName(); --functions can be called in declaration section
BEGIN
    x := functionName();
END;

Chiamare una funzione nella dichiarazione IF

IF functionName() = 100 THEN
    Null;
END IF;

Chiamare una funzione in un'istruzione SELECT

SELECT functionName() FROM DUAL;


Modified text is an extract of the original Stack Overflow Documentation
Autorizzato sotto CC BY-SA 3.0
Non affiliato con Stack Overflow