• db2中临时表在存储过程中的使用


    DROP PROCEDURE ADMINISTRATOR.SP_TEST (INTEGER, CHARACTER ());

    CREATE PROCEDURE administrator.sp_test(P1 INT, P2 CHAR(20))
    DYNAMIC RESULT SETS 1
    MODIFIES SQL DATA
    LANGUAGE SQL
    BEGIN
       DECLARE v_sqlstmt VARCHAR(8000);
       DECLARE CUR01 CURSOR WITH RETURN FOR SQL1;
       DECLARE GLOBAL TEMPORARY TABLE TT1(C1 INT, C2 CHAR(20)) WITH REPLACE;
      
       INSERT INTO SESSION.TT1 VALUES(P1, P2);
      
       set v_sqlstmt = 'SELECT * FROM SESSION.TT1 ';
       PREPARE SQL1 FROM v_sqlstmt;
       
       OPEN CUR01;  
      
    END

    ;

    --CALL administrator.SP_TEST(10,'123') 

    注意:

    1、临时表的使用必须有临时表空间

     命令: CREATE USER TEMPORARY TABLESPACE user_temp;  

    2、临时表只存在当前会话,如在当前会话中连续调用过程会出现临时表已经存在的问题, WITH  REPLACE的使用可以避免这样的情况,相当于Sql Server 中, 

    if exists(select * from tempdb..sysobjects where id=object_id('tempdb..##TEMP_TBL')) ,可以存在删除,不存在声明。
    3、临时表声明例:   DECLARE GLOBAL TEMPORARY TABLE TT1(C1 INT, C2 CHAR(20))  ON COMMIT PRESERVE ROWS;

     定义声明式全局临时表的每个会话拥有自己的独特的临时表描述。当会话终止时,表行和临时表描述均会被删除。

    有如下选项,可控制commit后临时表的状态:

         ON COMMIT DELETE ROWS:在执行 COMMIT 操作时,如果表上没有打开 WITH HOLD 游标,就删除表中的所有行。这是默认设置。

        ON COMMIT PRESERVE ROWS:在执行 COMMIT 操作时,保留表中的所有行。

        ON ROLLBACK DELETE ROWS:在执行 ROLLBACK(或 ROLLBACK to SAVEPOINT)操作时,如果已经修改了表数据,就删除表中的所有行。这是默认设置。

        ON ROLLBACK PRESERVE ROWS:在执行 ROLLBACK(或 ROLLBACK to SAVEPOINT)操作时,保留表中的所有行。

    delete rows用于事务相关,也就在事务结束后truncate data in the temporary table.

    preserve rows表示在会话结束后清除临时表的数据

    前者在事务提交后数据就已经清除了.

    后者在会话中止时或者导常退出时数据都会被清除掉.

  • 相关阅读:
    如何准备面试复试(1)
    如何应对糟糕的面试官(2)
    美国:经济危机让烟民吸烟量增加
    MOV 指令的注意事项
    一个简单的ajax无刷新翻页的程序
    SQL注入漏洞全接触
    php+mysql非暴力查表的注入语句写法总结
    在你的成长过程中,有五个人非常重要
    爱就在那里,不增不减
    php的一些书籍
  • 原文地址:https://www.cnblogs.com/flyingsanddream/p/4554940.html
Copyright © 2020-2023  润新知