db2界面调用存储过程_DB2 存储过程中执行动态SQL的两种写法

样本代码:

DROP PROCEDURE QUOTATION.COPY_SAMPLE;

CREATE PROCEDURE QUOTATION.COPY_SAMPLE (

IN tableNameFrom VARCHAR(30)

, IN tableNameTo VARCHAR(30)

, INOUT copyResult INTEGER)

BEGIN

DECLARE SQLCODE INTEGER DEFAULT 0;

SET copyResult = 0;

-- Proecss 1

BEGIN

DECLARE fromSql VARCHAR(32672);

DECLARE toSql VARCHAR(32672);

DECLARE seqTo VARCHAR(30);

DECLARE templateParserId INTEGER;

DECLARE uuid VARCHAR(36);

DECLARE stmt STATEMENT;

DECLARE curs CURSOR FOR stmt;

SET seqTo = 'SEQ_' || tableNameTo;

SET fromSql = 'SELECT MAX(TEMPLATE_PARSER_ID), UUID FROM QUOTATION.' || tableNameFrom || ' GROUP BY UUID';

PREPARE stmt FROM fromSql;

OPEN curs;

CURSORLOOP:

LOOP

FETCH curs INTO templateParserId, uuid;

-- Do nothing if no data or processed all datas.

IF SQLCODE = 100 THEN LEAVE CURSORLOOP;

END IF;

SET uuid = (SELECT CONCAT(HEX(RAND()), HEX(RAND())) FROM SYSIBM.SYSDUMMY1);

SET toSql = 'INSERT INTO QUOTATION.' || tableNameTo || ' (TEMPLATE_PARSER_ID, UUID) VALUES (NEXTVAL FOR QUOTATION.' || seqTo || ',''' || uuid || ''')';

PREPARE s FROM toSql;

EXECUTE s;

END LOOP;

CLOSE curs;

END;

-- Proecss 2

BEGIN

-- ......

END;

SET copyResult = 1;

END;

注意点:

1、SQLCODE必须要定义,且必须定义在最外层的BEGIN的下面。

2、必须要判断SQLCODE是否等于100,等于100时退出CURSORLOOP,否则会死循环。

3、“OPEN curs”之后不要忘记“CURSORLOOP:”。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值