返回行计数的DB2动态查询执行

时间:2012-07-05 05:26:54

标签: db2 prepared-statement dynamicquery execute-immediate

这里我试图在DB2中运行一个动态查询,它返回变量中的行数。

有没有人可以帮我解决如何将动态查询的结果存储到变量中以便我可以进一步使用它?以下是代码段: -

CREATE PROCEDURE SP_REC_COUNT ( )
  LANGUAGE SQL
  NOT DETERMINISTIC
  EXTERNAL ACTION
  MODIFIES SQL DATA
  CALLED ON NULL INPUT
  INHERIT SPECIAL REGISTERS
BEGIN
DECLARE SQL_STR VARCHAR(5000);
DECLARE V_TabSchema VARCHAR(50);
DECLARE V_TabName VARCHAR(100);
DECLARE CNT INTEGER DEFAULT 0;
DECLARE CountCur CURSOR FOR select TabSchema,TabName from SysCat.Tables where TabSchema='NGCORE' or TabSchema='NGCOREAU';
    OPEN CountCur;
        CountCur_Loop1:LOOP
        FETCH CountCur INTO  V_TabSchema,V_TabName;
        IF SQLCODE = 0
        THEN
          SET  SQL_STR ='select count(*) into CNT  from '|| V_TabSchema||'.'||V_TabName;
            PREPARE SQ FROM SQL_STR;
            execute  SQ;
            SET  SQL_STR ='INSERT INTO NGCORE_TMP.PHYISICAL_BACKOUT_REC_CNT(SCHEMA_NM,TABLE_NM,BEFORE_CNT)VALUES('''||V_TabSchema||''','''||V_TabName||''','||CNT||')';         
            PREPARE SQL FROM SQL_STR;
            EXECUTE SQL;
        ELSE
            CLOSE CountCur;
            LEAVE CountCur_Loop1;
        END If;
        END LOOP CountCur_Loop1;

END;

获得以下错误: - 错误[42703] [IBM] [DB2 / AIX64] SQL0206N“CNT”在使用它的上下文中无效。 SQLSTATE = 42703

1 个答案:

答案 0 :(得分:0)

我认为您需要首先发出PREPARE with an OUTPUT子句,然后发出EXECUTE with an INTO声明。

我似乎无法在IBM文档中找到一个示例。