Проверить запись НЕ НУЛЯ в plsql

У меня есть функция, которая возвращала бы запись с типом my_table% ROWTYPE , и в вызывающей программе я мог проверить, является ли возвращенная запись нулевой, но PL / SQL жалуется на оператор if, который

PLS-00306: неправильное количество или типы аргументов при вызове ' IS NOT NULL '

Вот мой код:

v_record my_table%ROWTYPE;
v_row_id my_table.row_id%TYPE := 123456;
begin
    v_record := myfunction(v_row_id)
    if (v_record is not null) then
        -- do something
    end if;
end;

function myfunction(p_row_id in my_table.row_id%TYPE) return my_table%ROWTYPE is
    v_record_out my_table%ROWTYPE := null;
begin
    select * into v_record_out from my_table
    where row_id = p_row_id;
    return v_record_out;
end myfunction;

Спасибо.

21
задан Sapience 26 August 2011 в 16:39
поделиться