偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

在SQL過程和SQL語句中測試DB2臨時表

數(shù)據(jù)庫
本文將會為您測試在分別在SQL過程以及SQL語句中創(chuàng)建臨時表,并插入數(shù)據(jù)后,執(zhí)行結(jié)果有何異同之處,供您參考,希望對您有所啟迪。

本文將會為您測試在DB2數(shù)據(jù)庫中,分別在SQL過程以及SQL語句中創(chuàng)建臨時表,并插入數(shù)據(jù)后,執(zhí)行結(jié)果有何異同之處,供您參考,希望對您有所啟迪。
 
測試目標(biāo):
 
分別在SQL過程和SQL語句中創(chuàng)建臨時表,并插入數(shù)據(jù),看執(zhí)行結(jié)果有什么異同。
 
測試環(huán)境:
 
DB2 UDB V9.1
 
執(zhí)行附件里面的SQL語句,得到一個表。
 
測試代碼和運行結(jié)果:
 
一、臨時
DB2臨時表在SQL過程和SQL語句中的測試總結(jié)
 
測試目標(biāo):
 
分別在SQL過程和SQL語句中創(chuàng)建臨時表,并插入數(shù)據(jù),看執(zhí)行結(jié)果有什么異同。
 
測試環(huán)境:
 
DB2 UDB V9.1
 
執(zhí)行附件里面的SQL語句,得到一個表。#p#
 
測試代碼和運行結(jié)果:
 
一、臨時表在SQL語句中
 
-- 定義一個全局臨時表SESSION.RESULT
DECLARE GLOBAL TEMPORARY TABLE SESSION.RESULT
    ( 
         TMP_HYDM   VARCHAR(10),    -- 行業(yè)代碼
         TMP_HYMC   VARCHAR(300)   -- 行業(yè)名稱
    )
     WITH REPLACE
  NOT LOGGED; 
-- 插入數(shù)據(jù)到臨時表   
INSERT INTO  SESSION.RESULT
SELECT MLDM,MLMC FROM DM_HY_CY;
 
-- 查詢臨時表數(shù)據(jù)   
SELECT * FROM SESSION.RESULT;
 
測試結(jié)果:以上SQL代碼正常執(zhí)行,但是沒有查詢到任何數(shù)據(jù)。
 
 二、臨時表在SQL存儲過程中
 
CREATE PROCEDURE SP_TEST_TMEP (  )#p#
        DYNAMIC RESULT SETS 1
------------------------------------------------------------------------
-- 語言:DB2 SQL 存儲過程
------------------------------------------------------------------------
P1: BEGIN
        -- 定義一個全局臨時表SESSION.RESULT
        DECLARE GLOBAL TEMPORARY TABLE SESSION.RESULT
            ( 
                        TMP_HYDM   VARCHAR(10),   -- 行業(yè)代碼
                        TMP_HYMC   VARCHAR(300)   -- 行業(yè)名稱
            )
             WITH REPLACE       -- 如果存在此臨時表,則替換                            
                 NOT LOGGED;    -- 不在日志里紀(jì)錄
 
         -- 插入數(shù)據(jù)到臨時表
        INSERT INTO  SESSION.RESULT
        SELECT MLDM,MLMC FROM DM_HY_CY;#p#
 
P2: BEGIN
        -- 游標(biāo)對客戶機應(yīng)用程序保持打開
        DECLARE CUR_RES CURSOR WITH RETURN FOR
                SELECT * FROM SESSION.RESULT;
        OPEN CUR_RES;
END P2;
END P1
 
測試結(jié)果:存儲過程執(zhí)行成功,并返回了插入的目標(biāo)數(shù)據(jù)。
 
測試總結(jié):
 
1、在SQL語句中,構(gòu)建臨時表是沒有意義的,因為當(dāng)SQL語句執(zhí)行處于自動提交模式下時,執(zhí)行后就COMMIT了,而一旦執(zhí)行了COMMIT語句,臨時表將從內(nèi)存中清除。
 
2、在SQL過程中,臨時表定義后,如果沒有顯式執(zhí)行到COMMIT語句,則臨時表一直存在。并且臨時表支持INSERT INTO ... SELECT ... 的語句。
 
3、在DB2下,臨時表的模式必須為SESSION,SESSION模式下表是一個內(nèi)存表,這個SESSION是DB2特有的SCHEMA,SESSION對象的聲明周期僅僅限于一次數(shù)據(jù)連接“會話”,一旦會話結(jié)束,SESSION對象就被從內(nèi)存中清除了,這和JSP中的內(nèi)置對象SESSION類似。
 
 

責(zé)任編輯:段燃 來源: 互聯(lián)網(wǎng)
相關(guān)推薦

2010-11-04 15:39:40

DB2 SQL語句

2010-09-06 15:13:05

DB2

2010-11-11 11:25:45

SQL UPDATE語

2009-07-22 14:44:36

ibmdw

2010-11-01 11:13:57

DB2表管理

2010-11-02 14:37:58

DB2臨時表定義

2010-11-04 13:55:26

DB2 SQL腳本批量

2010-09-06 10:43:15

DB2 SQL存儲過程

2010-11-03 11:55:23

DB2公共表表達式

2010-08-05 10:20:29

DB2數(shù)據(jù)庫動態(tài)

2010-09-01 10:08:54

DB2SQL語句

2011-08-17 21:49:55

建立視圖SQL ServerOracle

2011-08-17 21:23:41

約束NOT NULLUNIQUE

2010-08-18 13:59:04

DB2純SQL存儲過程

2010-09-06 10:54:52

DB2 sql 存儲過

2011-08-17 20:48:25

索引建立語句非聚集索引唯一索引

2010-09-30 16:00:40

DB2動態(tài)SQL

2010-11-04 12:00:59

db2存儲過程

2011-08-22 17:41:25

SQL ServerOracleDB2

2010-08-05 14:50:23

DB2動態(tài)SQL
點贊
收藏

51CTO技術(shù)棧公眾號