DB2 存储过程中执行动态SQL的两种写法
生活随笔
收集整理的這篇文章主要介紹了
DB2 存储过程中执行动态SQL的两种写法
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
樣本代碼:
DROP PROCEDURE QUOTATION.COPY_SAMPLE; CREATE PROCEDURE QUOTATION.COPY_SAMPLE (IN tableNameFrom VARCHAR(30), IN tableNameTo VARCHAR(30), INOUT copyResult INTEGER)BEGINDECLARE SQLCODE INTEGER DEFAULT 0;SET copyResult = 0;-- Proecss 1BEGINDECLARE 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:LOOPFETCH 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 2BEGIN-- ......END;SET copyResult = 1; END;注意點:
1、SQLCODE必須要定義,且必須定義在最外層的BEGIN的下面。
2、必須要判斷SQLCODE是否等于100,等于100時退出CURSORLOOP,否則會死循環(huán)。
3、“OPEN curs”之后不要忘記“CURSORLOOP:”。
轉(zhuǎn)載于:https://blog.51cto.com/13685327/2146247
總結(jié)
以上是生活随笔為你收集整理的DB2 存储过程中执行动态SQL的两种写法的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: centos6.8 环境一键安装包 ng
- 下一篇: PostgreSQL 并行查询概述