如何从 SQuirreL SQL 调用带有 OUT 参数的 DB2 存储过程?

发布于 2024-10-17 11:48:55 字数 187 浏览 10 评论 0原文

我真的很喜欢 SQuirreL SQL 作为 SQL 查询工具,但我一直无法让它调用我们的 AS/400 DB2 数据库中的存储过程。我总是收到错误“设置或注册的参数值的数量与参数的数量不匹配。”我已经仔细检查了参数的数量,但没有运气。这是我为一个需要一个输入和一个输出的过程尝试过的语法:

call SOMESPROC(12345, ?);

I really like SQuirreL SQL as a SQL query tool, but I've never been able to get it to call stored procedures in our AS/400 DB2 database. I always get the error "The number of parameter values set or registered does not match the number of parameters." I've double-checked the number of params and had no luck. This is the syntax I've tried for a procedure that takes one IN and one OUT:

call SOMESPROC(12345, ?);

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(9

我家小可爱 2024-10-24 11:48:55

SQuirrel 目前似乎无法在 AS/400 DB2 上执行此操作。

使用开源“SQL Workbench/J”(http://www.sql-workbench.net/) 我能够调用一个过程:

wbcall SOMESPROC(12345, ?);

它有自己的用于调用过程“wbcall”的命令。使用 ?对于输出参数。

注意:安装 SQL Workbench/J 时,请确保从 下载正确的 DB2 驱动程序IBM 并在 SQL Workbench/J 中添加驱动程序时添加许可证文件。

It seems that SQuirrel currently is not capable of doing that on AS/400 DB2.

Using the open source "SQL Workbench/J" (http://www.sql-workbench.net/) I was able to call a procedure:

wbcall SOMESPROC(12345, ?);

It has its own command for calling a procedure "wbcall". Use ? for out parameters.

Note: While installing SQL Workbench/J make sure to download the right DB2 driver from IBM and also add the licence file while adding the driver inside SQL Workbench/J.

琴流音 2024-10-24 11:48:55

在 Squirrel 中你可以使用这样的东西。您需要确保声明的变量的类型与存储过程中的输出参数的类型匹配。

BEGIN
    DECLARE outParam INT;
    STORED_PROC_NAME(outParam);
END

如果您还需要为该过程提供输入,您可以这样做。

BEGIN
    DECLARE outParam INT;
    STORED_PROC_NAME('input', outParam);
END

您还需要将语句分隔符更改为 ; 以外的内容。否则,它将分解该语句并尝试单独发送每个部分。

In Squirrel you can use something like this. You'll want to make sure the type of the declared variable matches the type of your out parameter in the stored procedure.

BEGIN
    DECLARE outParam INT;
    STORED_PROC_NAME(outParam);
END

If you also need to provide input for the procedure you could do this.

BEGIN
    DECLARE outParam INT;
    STORED_PROC_NAME('input', outParam);
END

You also need to change the statement separator to something other than ;. Otherwise it will break up the statement and try to send each piece individually.

意犹 2024-10-24 11:48:55

在 DbVisualizer 专业版中,启用 SQL Commander 菜单选项下的“SQL 中的处理参数标记”后,它将允许“?”参数

call SOMESPROC(12345, ?);

In the pro version of DbVisualizer, with the "Process Parameter Markers in SQL" under the SQL Commander menu option enabled, it will allow the "?" param

call SOMESPROC(12345, ?);
怪我入戏太深 2024-10-24 11:48:55

经过反复试验,我在 Squirrel 中看到了结果。

create or replace variable var4 char(1);
create or replace variable var5 decimal(3,0);
create or replace variable var6 char(60);
call getthedata('XXX',123456789,'1234567',var4,var5,var6);
select var4,var5,var6 from sysibm.sysdummy1;  -- displays OUT parms

through trial and error, I was able to see the results in Squirrel.

create or replace variable var4 char(1);
create or replace variable var5 decimal(3,0);
create or replace variable var6 char(60);
call getthedata('XXX',123456789,'1234567',var4,var5,var6);
select var4,var5,var6 from sysibm.sysdummy1;  -- displays OUT parms
許願樹丅啲祈禱 2024-10-24 11:48:55

我认为,如果其中有一个,那么调用应该是:

CALL SomeSProc(12345)

要得到结果,可以尝试:

SELECT * FROM SomeSProc(12345)

I would think that if there is one in then the call should be:

CALL SomeSProc(12345)

to get a result maybe try:

SELECT * FROM SomeSProc(12345)
月牙弯弯 2024-10-24 11:48:55

下面是一个经过测试的示例,它使用 db2 存储过程在 Squirrel 3.7 上运行。诀窍是通过过渡存储过程 MY_PROC_TEST 来调用真正的存储过程 PROC_TEST。

松鼠中的更改语句分隔符>会话>会话属性> SQL : @

DROP PROCEDURE MY_PROC_TEST()@
CREATE PROCEDURE MY_PROC_TEST()
RESULT SETS 1 -- out resultset (call product)
LANGUAGE SQL
BEGIN
  DECLARE flag SMALLINT; -- out parameter
  CALL MY_PROC('2015', flag);
END @
CALL MY_PROC_TEST()@
END @

然后你可以像这样调用这个过程:

CALL MY_PROC_TEST()@

Here is an tested example which works on Squirrel 3.7 with a db2 stored procedure . The trick is to passe with an transitional stored procedure MY_PROC_TEST to call the real stored procedure PROC_TEST.

change statement separator in squirrel > session > session properties > SQL : @

DROP PROCEDURE MY_PROC_TEST()@
CREATE PROCEDURE MY_PROC_TEST()
RESULT SETS 1 -- out resultset (call product)
LANGUAGE SQL
BEGIN
  DECLARE flag SMALLINT; -- out parameter
  CALL MY_PROC('2015', flag);
END @
CALL MY_PROC_TEST()@
END @

Then you can call the sored procedure like this :

CALL MY_PROC_TEST()@

心的憧憬 2024-10-24 11:48:55

如果您更改分隔符(如上所述),这将在 Squirrel 中起作用。但是,要查看变量是什么,您需要执行以下操作...

在我的示例中,我将分隔符设置为斜线 (~)。包括在最后一个“end”之后、“select”之前。代码从这里开始...

begin
declare inoutParm numeric(2,0);
call spMyStoredProcedure(
             1234567                                     
           , inoutParm                                           
       );
declare global temporary table session.myTempTbl  
       (MyResult   char(1024) )                                         
with replace ;
insert into session.myTempTbl
  (myResult)
   values(inoutParm) ;  
end
~
select myResult from session.myTempTbl

Mic Keeley
as400(db2) SQL 开发人员

This will work in Squirrel if you change the delimiter (as specified above). However, to see what the variable is, you need to do the following...

In my example, I will set the delimiter to a tildy (~). Include after last "end", before "select". Code begins here...

begin
declare inoutParm numeric(2,0);
call spMyStoredProcedure(
             1234567                                     
           , inoutParm                                           
       );
declare global temporary table session.myTempTbl  
       (MyResult   char(1024) )                                         
with replace ;
insert into session.myTempTbl
  (myResult)
   values(inoutParm) ;  
end
~
select myResult from session.myTempTbl

Mic Keeley
as400(db2) SQL Developer

已下线请稍等 2024-10-24 11:48:55

我能够将上述所有答案拼凑在一起,并得出对我有用的答案。我正在使用 Squirrel SQL 2018 连接到 IBM AS/400 DB2 数据库。我确实必须声明一个语句分隔符,我使用了“#”。

    BEGIN
        DECLARE success CHAR(1); -- output parameters
        DECLARE message CHAR(300);
        SET success = ' '; 
        SET message = ' ';
        CALL myProc('some', 'params', 4, success, message); 
        DECLARE GLOBAL TEMPORARY TABLE session.myTmp(s_res CHAR(1), m_res CHAR(300)) WITH REPLACE; 
        INSERT INTO session.myTmp(s_res, m_res) VALUES(success, message);
    END
    # -- <- statement separator needs to be set to something other than ";" in this case it's set to "#"
    SELECT * FROM session.myTmp;

I was able to cobble together some amalgamation of all of the above answers and came up with this which worked for me. I'm using Squirrel SQL 2018 connecting to an IBM AS/400 DB2 database. I did have to declare a statement separator, I used "#".

    BEGIN
        DECLARE success CHAR(1); -- output parameters
        DECLARE message CHAR(300);
        SET success = ' '; 
        SET message = ' ';
        CALL myProc('some', 'params', 4, success, message); 
        DECLARE GLOBAL TEMPORARY TABLE session.myTmp(s_res CHAR(1), m_res CHAR(300)) WITH REPLACE; 
        INSERT INTO session.myTmp(s_res, m_res) VALUES(success, message);
    END
    # -- <- statement separator needs to be set to something other than ";" in this case it's set to "#"
    SELECT * FROM session.myTmp;
只是我以为 2024-10-24 11:48:55

松鼠中的更改语句分隔符>会话>会话属性> SQL:'#'

BEGIN
    DECLARE inOutParam varchar(200);
    set inOutParam =  'a value';
    STORED_PROC_NAME(outParam);
END;
#

change statement separator in squirrel > session > session properties > SQL : '#'

BEGIN
    DECLARE inOutParam varchar(200);
    set inOutParam =  'a value';
    STORED_PROC_NAME(outParam);
END;
#
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文