Поиск…


Синтаксис

  • CREATE [OR REPLACE] FUNCTION имя_функции [(параметр [, параметр])]

    RETURN return_datatype

    IS | КАК

    [Declaration_section]

    BEGIN исполняемый_секретарь

    [EXCEPTION exception_section]

    END [имя_функции];

Создать 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;

Функции вызова

Существует несколько способов использования функций.

Вызов функции с оператором присваивания

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

Вызов функции в выражении IF

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

Вызов функции в выражении SELECT

SELECT functionName() FROM DUAL;


Modified text is an extract of the original Stack Overflow Documentation
Лицензировано согласно CC BY-SA 3.0
Не связан с Stack Overflow