Oracle
 sql >> Base de données >  >> RDS >> Oracle

Appeler la procédure stockée à partir de sqlplus

Le deuxième paramètre de votre procédure est un OUT paramètre -- sa valeur sera affectée à la variable transmise à la fin de la procédure. Vous ne pouvez donc pas utiliser de valeur littérale pour ce paramètre.

Vous pouvez déclarer une variable de liaison à l'invite SQLPlus et l'utiliser :

-- 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

Alternativement, vous pouvez utiliser un bloc PL/SQL anonyme :

-- 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;
/