【问题标题】:Call stored procedure from sqlplus从 sqlplus 调用存储过程
【发布时间】:2011-12-19 08:26:15
【问题描述】:

如何从sqlplus调用存储过程?

我有一个程序:

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

Do something

end;

我试过 exec testproc(12,89) ::返回错误

【问题讨论】:

  • 一般来说,最好直接说出你遇到了什么错误,而不是仅仅说“返回错误”

标签: sql vb.net oracle oracle11g


【解决方案1】:

过程的第二个参数是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;
/

【讨论】:

    【解决方案2】:
       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);
    

    试试这个,如果你有问题再发给我:)

    【讨论】:

    • CREATE OR REPLACE PROCEDURE TESTSQLRULEPROC(param1 in varchar2, param2 out varchar2) AS BEGIN IF TO_Number(param1) 20 THEN param2 := '值太高。'; ELSE param2:= 'NULL';万一;其他情况除外 param2:= 'Not a Number!'; END TESTSQLRULEPROC;
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2016-07-11
    • 1970-01-01
    • 1970-01-01
    • 2011-10-23
    • 2011-05-05
    • 1970-01-01
    相关资源
    最近更新 更多