Вторият параметър на вашата процедура е 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;
/