oracle 存储过程堆栈,oracle - 在SQL Developer中运行存储过程? - 堆栈内存溢出

用户在尝试从SQLDeveloper 2.1.1.64版运行一个具有多个输入和输出参数的存储过程时遇到问题。他们无法直接运行过程,菜单选项为灰色。尝试创建匿名块执行该过程时,遇到了关于未声明的绑定变量的错误。在尝试去掉输出参数前的冒号后,遇到了PLS-00103编译错误。寻求解决在SQLDeveloper中正确调用该存储过程的方法。
摘要由CSDN通过智能技术生成

我正在尝试运行具有多个输入输出参数的存储过程。 只能通过导航“其他用户” |“我的连接”面板来查看该过程。 | 套餐| |

如果我单击鼠标右键,则菜单项为“订购成员依据...”和“创建单元测试”(显示为灰色)。 当用户访问该过程时,似乎无法“运行”该过程。

我一直在尝试找到一个示例,该示例说明如何创建匿名块,以便可以将过程作为SQL文件运行,但没有找到任何有效的方法。

有谁知道如何从SQL Developer执行此过程? 我正在使用2.1.1.64版。

提前致谢!

编辑1:

我要调用的过程具有以下签名:

user.package.procedure(

p_1 IN NUMBER,

p_2 IN NUMBER,

p_3 OUT VARCHAR2,

p_4 OUT VARCHAR2,

p_5 OUT VARCHAR2,

p_6 OUT NUMBER)

如果我这样写我的匿名块:

DECLARE

out1 VARCHAR2(100);

out2 VARCHAR2(100);

out3 VARCHAR2(100);

out4 NUMBER(100);

BEGIN

EXECUTE user.package.procedure (33,89, :out1, :out2, :out3, :out4);

END;

我收到错误:

Bind Varialbe "out1" is NOT DECLCARED

anonymous block completed

我试过初始化out *变量:

out1 VARCHAR2(100) := '';

但得到同样的错误:

编辑2:

根据Alex的回答,我尝试从参数前面移除冒号并得到以下信息:

Error starting at line 1 in command:

DECLARE

out1 VARCHAR2(100);

out2 VARCHAR2(100);

out3 VARCHAR2(100);

out4 NUMBER(100);

BEGIN

EXECUTE user.package.procedure (33,89, out1, out2, out3, out4);

END;

Error report:

ORA-06550: line 13, column 17:

PLS-00103: Encountered the symbol "USER" when expecting one of the following:

:= . ( @ % ; immediate

The symbol ":=" was substituted for "USER" to continue.

06550. 00000 - "line %s, column %s:\n%s"

*Cause: Usually a PL/SQL compilation error.

*Action:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值