Chinaunix

标题: 关于DB2存储过程的调用问题! [打印本页]

作者: gaoxiandong_123    时间: 2003-08-16 14:31
标题: 关于DB2存储过程的调用问题!
我有一个SQL存储过程:
CREATE PROCEDURE DB2ADMIN.gxdtest1(
    in  a1  varchar(10),
    in  a2  varchar(10),
    out a   int)
    LANGUAGE SQL
------------------------------------------------------------------------
-- SQL 存储过程
------------------------------------------------------------------------
P1: BEGIN
insert into gxd123 values(a1,current date);   
set a=9;
END P1              
   此过程在spb中调用是成功的,
问题::
我在命令行执行时
db2 =>; call gxdtest1(12,2)
DB21101E  为存储过程指定的命令行参数太少。

db2 =>; call gxdtest1(12,2,3)
DB21101E  为存储过程指定的命令行参数太少。

db2 =>; call gxdtest1(12,2,3,2)
DB21103W  指定的输入参数太多(应为 3)。

db2 =>; call gxdtest1(12,2,3)
DB21101E  为存储过程指定的命令行参数太少。

db2 =>; call gxdtest1(12,2,a)
DB21101E  为存储过程指定的命令行参数太少。

db2 =>; call gxdtest1(12,2)
DB21101E  为存储过程指定的命令行参数太少。

我该如何调用呀?????
作者: Law    时间: 2003-08-16 15:09
标题: 关于DB2存储过程的调用问题!
db2=>;call gxdtest1(12,2,?)
作者: xipeng    时间: 2003-08-22 15:23
标题: 关于DB2存储过程的调用问题!
果然可以,为何加个"?",想知道
作者: 3000sunqin    时间: 2003-08-25 13:02
提示: 作者被禁止或删除 内容自动屏蔽
作者: xipeng    时间: 2003-08-27 14:02
标题: 关于DB2存储过程的调用问题!
是吗?谢谢3000sunqin.
哦,是不是输出参数因为不知是多少,所以用"?"来代替呢?
假如输出参数有不只一个,是不是还是用一个"?"呢?
作者: vlife    时间: 2003-08-28 09:34
标题: 关于DB2存储过程的调用问题!
多个“?”,否则告诉你参数个数不对
作者: Law    时间: 2003-08-29 08:45
标题: 关于DB2存储过程的调用问题!
一个输出使用一个?号,有几个就用几个?号




欢迎光临 Chinaunix (http://bbs.chinaunix.net/) Powered by Discuz! X3.2