Вызов хранимой процедуры из sqlplus - PullRequest
3 голосов
/ 19 декабря 2011

Как вызвать хранимую процедуру из sqlplus?

У меня есть процедура:

Create or replace procedure testproc(parameter1 in varachar2,parameter2 out varchar2)
begin

Do something

end;

Я попытался exec testproc(12,89) :: Возвращает ошибку

Ответы [ 2 ]

10 голосов
/ 19 декабря 2011

Второй параметр вашей процедуры - это параметр OUT - его значение будет присвоено переменной, переданной по завершении процедуры.Таким образом, вы не можете использовать литеральное значение для этого параметра.

Вы можете объявить переменную связывания в приглашении SQLPlus и использовать это:

-- Declare bind variable
VARIABLE x NUMBER

-- If necessary, initialize the value of x; in your example this should be unnecessary
-- since the value of the second parameter is never read
EXEC :x := 1

-- Call the procedure
EXEC testproc(12, :x)

-- Print the value assigned to the bind variable
PRINT x

В качестве альтернативы, вы можете использовать анонимный PLБлок SQL:

-- Activate client processing of dbms_output buffer
SET SERVEROUTPUT ON

-- In anonymous block, declare variable, call procedure, print resulting value
DECLARE
  x NUMBER;
BEGIN
  testproc(12, x);
  dbms_output.put_line( x );
END;
/
3 голосов
/ 19 декабря 2011
   create or replace procedure autogenerate(t1 in int,t2 in int)
   is
   jum number;
   begin 
            if t1 < 10 then 
            dbms_output.put_line('Value too low.');
                else if t1 > 20 then 
                dbms_output.put_line('Value too high.');
                end if;
            end if;
   end;
   /
   show errors;
   set serveroutput on;
   execute autogenerate(1,2);

Попробуйте, если у вас есть вопрос, просто напишите мне снова:)

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...