用空游标调用oracle过程?

时间:2012-10-16 12:34:48

标签: sql oracle stored-procedures plsql

我有一个看起来像这样的程序:

  PROCEDURE myprocedure (
      i_area        IN       somenumber%TYPE,
      io_areadata   IN OUT   areacursor
   );

我想知道是否有任何简单的方法来调用程序?我有第一个参数的数据但是第二个我不知道输入什么。有什么方法可以输入空光标或类似的东西吗?

这是我到目前为止所做的:

BEGIN
package.myprocedure (
      12345
   );
END;

这给了我以下错误:

Error report:
ORA-06550: row 2, column 1:
PLS-00306: wrong number or types of arguments in call to 'MYPROCEDURE'
ORA-06550: row 2, column 1:
PL/SQL: Statement ignored
06550. 00000 -  "line %s, column %s:\n%s"
*Cause:    Usually a PL/SQL compilation error.

提前谢谢,对不起我的(可能)不好的解释。我在PL / SQL方面经验不足。

2 个答案:

答案 0 :(得分:3)

您必须提供该参数。你可以这样做:

DECLARE
   dummy package.areacursor;
BEGIN
package.myprocedure (
      12345, dummy
   );
END;

答案 1 :(得分:0)

通过这种方式,您可以通过将特定值传递给特定参数来调用存储过程。 试试这个。

Begin

package.myprocedure(i_area => '12345);

end;