亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > 綜合 > 正文

DB2中的數據移動——裝入(1)

2024-07-21 02:41:26
字體:
來源:轉載
供稿:網友
  裝入(Load)  裝入命令格式與導入類似,命令要害字是Load,但是后面的參數比導入命令多的多,具體用法可以自行參考DB2文檔?! ⊙b入與導入類似,都是將輸入文件中的數據移入到目標表中,二者的不同點將在實例中逐步解釋。  在裝入之前,目標表必須已經存在?! ⊙b入的性能比導入高,原因在后面結合實例具體解釋。  裝入操作不記錄到日志中,所以不能使用日志文件進行前滾操作?! ⊙b入分為4個階段:  1. 裝入階段  在這個階段發生兩件事:數據存儲在表中,收集索引鍵并排序。在裝入時,DBA可以指定多長時間生成一致點?! ∷茄b入工具的檢查點。假如裝入在執行期間被打斷,它可以從最后一個一致點處開始繼續重新執行?! ?. 構建階段  在構建階段,基于在裝入階段收集的索引鍵信息創建索引。假如在構建階段發生錯誤,裝入工具就重啟,它將從構建階段開始處重新開始構建?! ?. 在刪除階段,所有違反唯一或主鍵約束的行都被刪除并拷貝到一個異常表(假如在語句中指定相應選項)中。當輸入行被拒絕,消息文件中就生成消息。  4. 索引拷貝階段  假如在裝入操作期間為索引創建指定了系統臨時表空間,并且選擇了 READ access 選項,該索引數據將從系統臨時表空間拷貝到原來的表空間?! ⊙b入過程的所有四個階段都是操作的一部分,只有在所有的四個階段都完成之后,該裝入操作才算完成。在每個階段都將生成消息,一旦其中的某個階段發生錯誤,這些消息可以幫助DBA分析并解決問題。  導入操作每次插入一行數據時都要檢查是否滿足約束條件,并且記入日志文件中?! ∠旅嫖覀兛匆恍㎜OAD命令特有的功能,IMPORT命令也能做的就不再具體說了。 123456下一頁   例十二:從光標類型文件中進行裝入  定義一個cursor  declare mycur cursor for select * from org  創建一個新表,結構與cursor相容  create table org2 like org  從cursor中裝入  load from mycur of cursor insert into org2  除了可以從cursor中裝入,還可以從文件、管道、設備中進行裝入。而導入命令只能從文件中導入?! ±宏P于異常表  由用戶定義的異常表可以用于存儲不遵循唯一約束和主碼約束的行。假如裝入的時候沒有指定異常表,則違反唯一約束的行將被丟棄并且將不再有機會恢復或修改?! ∮肧AMPLE數據庫中的STAFF表做實驗  1. 創建一個結構與STAFF表相同的表STAFF1  CREATE TABLE STAFF1 LIKE STAFF  2. 把STAFF表中的一部分數據插入到STAFF1中  INSERT INTO STAFF1 SELECT * FROM STAFF WHERE ID<=160  3. 再創建一個結構與STAFF1相同的表STAFFEXP,作為異常表  CREATE TABLE STAFFEXP LIKE STAFF1  4. 給該異常表添加一列,因為異常表和普通表相比,前面的結構都相同,就是最后多出一列或兩列(列名任意),第一列是時間戳類型,記錄異常記錄插入的時間,第二列是大文本類型(至少為32K大?。?,保存導致該條記錄被拒絕的特定約束信息。本例中只添加一個時間戳列。  ALTER TABLE STAFFEXP ADD COLUMN TIME TIMESTAMP  5. 為STAFF1表創建一個唯一索引  CREATE UNIQUE INDEX IDXSTAFF ON STAFF1(ID)  6. 先運行導出命令做出一個文本文件  EXPORT TO D:STAFF.TXT OF DEL SELECT * FROM STAFF  7. 然后運行裝入命令把數據再裝入到STAFF1表中  LOAD FROM D:STAFF.TXT OF DEL INSERT INTO STAFF1 FOR EXCEPTION STAFFEXP 上一頁123456下一頁   由于表STAFF1中有唯一索引,所以會有一部分數據因為違反這個約束條件而不能插入到STAFF1表中,這些記錄就會插入到異常表STAFFEXP中?! ∽⒅匾稽c,異常表必須自己先定義好,裝入命令不能夠自動生成異常表,假如找不到指定的異常表,就會報錯?! ±模宏P于DUMP文件  格式不正確的行會被拒絕。通過指定DUMPFILE文件類型修飾符可以使這些被拒絕的記錄單獨放在指定的文件里?! ∮肧AMPLE數據庫中的STAFF表做實驗  1. 創建一個結構與STAFF表相同的表STAFF1  CREATE TABLE STAFF1 LIKE STAFF  2. 把STAFF表中的一部分數據插入到STAFF1中  INSERT INTO STAFF1 SELECT * FROM STAFF WHERE ID<=160  3. 再創建一個結構與STAFF1相同的表STAFFEXP,作為異常表  CREATE TABLE STAFFEXP LIKE STAFF1  4. 給該異常表添加一列  ALTER TABLE STAFFEXP ADD COLUMN TIME TIMESTAMP  5. 為STAFF1表創建一個唯一索引  CREATE UNIQUE INDEX IDXSTAFF ON STAFF1(ID)  6. 先運行導出命令做出一個文本文件  EXPORT TO D:STAFF.TXT OF DEL SELECT * FROM STAFF  到D盤上打開STAFF.TXT文件,把第一列等于320的行替換為:"abcf","aaa","sdfg"  7. 然后運行裝入命令把數據再裝入到STAFF1表中  LOAD FROM D:STAFF.TXT OF DEL MODIFIED BY DUMPFILE=d:dump INSERT INTO STAFF1 FOR EXCEPTION STAFFEXP  裝入的結果報告中會有如下一條:  SQL3118W 在行 "32" 列 "1" 中的字段值不能轉換為 SMALLINT 值,但是目標列不可為空。未裝入該行?! QL3185W 當處理輸入文件的第 "32" 行中的數據時發生先前的錯誤。 上一頁123456下一頁   打開D盤的dump.000文件,會看到造成異常的那一行數據:"abcf","aaa","sdfg"  通過這個例子,我們可以理解,假如一行數據的格式不正確,在裝入的時候會遭到拒絕,該行記錄會放到DUMP文件中;而假如數據格式正確,但是不滿足表的約束條件,該行記錄會放到異常表中?! ±澹合拗蒲b入行數  用ROWCOUNT選項可以指定從文件開始處裝入的記錄數  LOAD FROM D:STAFF.TXT OF DEL ROWCOUNT 3 INSERT INTO STAFF1  例十六:出現警告信息時強令裝入操作失敗  在某些情況下,文件中的數據必須全部成功輸入到目標表中才算成功,即使有一條記錄出錯也不行。在這種情況下,可以使用WARNINGCOUNT選項?! 〉紻盤上打開STAFF.TXT文件,把第一列等于320的行替換為:"abcf","aaa","sdfg"  LOAD FROM D:STAFF.TXT OF DEL WARNINGCOUNT 1 INSERT INTO STAFF1  運行結果包含下面的警告:  SQL3118W 在行 "32" 列 "1" 中的字段值不能轉換為 SMALLINT值,但是目標列不可為空。未裝入該行。  SQL3185W 當處理輸入文件的第 "32" 行中的數據時發生先前的錯誤。  SQL3502N 實用程序碰到了 "1" 個警告,它超過了答應的最大警告數?! 〈藭r無法對表STAFF1進行操作,例如  SELECT * FROM STAFF1  會返回:  ID   NAME   DEPT  JOB  YEARS SALARY  COMM  ------ --------- ------ ----- ------ --------- ---------  SQL0668N 由于表 "USER.STAFF1" 上的原因代碼 "3",所以不答應操作。  SQLSTATE=57016 上一頁123456下一頁   原因是:表處于“裝入掛起”狀態。對此表的先前的 LOAD 嘗試失敗。在重新啟動或終止 LOAD 操作之前不答應對表進行存取。  解決方法為:通過分別發出帶有 RESTART 或 TERMINATER 選項的 LOAD 來重新啟動或終止先前失敗的對此表的 LOAD 操作。  包含TERMINATER的LOAD命令可以終止裝入進程,使目標表恢復正??捎脿顟B:  LOAD FROM D:STAFF.TXT OF DEL TERMINATE INTO STAFF1  包含RESTART的LOAD命令可以在源文件修改正確的時候使用,使裝入進程重新開始:  LOAD FROM D:STAFF.TXT OF DEL RESTART INTO STAFF1  例十七:防止產生警告信息  使用NOROWWARNINGS文件類型修飾符可以禁止產生警告信息,當裝入過程可能出現大量警告信息,而用戶對此又不感愛好的時候,可以使用該選項,這樣可以大大提高裝入的效率  到D盤上打開STAFF.TXT文件,把第一列等于320的行替換為:"abcf","aaa","sdfg"  LOAD FROM D:STAFF.TXT OF DEL MODIFIED BY NOROWWARNINGS INSERT INTO STAFF1  運行完的結果中,第32行出錯,該行無法裝入,但是不產生警告信息?! ±耍荷山y計數據  使用STATISTICS選項可以在裝入的過程中生成統計數據,這些統計數據可以供優化器確定最有效的執行SQL語句的方式。  可以對表和索引產生不同具體程度的統計數據: ?、?對表和索引產生最具體的統計數據:  LOAD FROM D:STAFF.TXT OF DEL REPLACE INTO STAFF1 STATISTICS YES WITH DISTRIBUTION AND DETAILED INDEXES ALL  ② 對表和索引都產生簡略的統計:  LOAD FROM D:STAFF.TXT OF DEL REPLACE INTO STAFF1 STATISTICS YES AND INDEXES ALL 上一頁123456下一頁   其它組合可以參考DB2文檔?! ∽⒅兀篠TATISTICS選項只能和REPLACE兼容,與INSERT選項不兼容。  另外,通過STATISTICS選項做完統計,我們看不到任何直接的結果,假如想查看其結果,需要到系統表中自己查詢?! ±牛航獬龣z查掛起狀態  1. 連接到SAMPLE數據庫上:  Connect to sample  2. 創建一個結構與staff表相同的表:  CREATE TABLE STAFF1 LIKE STAFF  3. 給該表添加一個檢查約束:  alter table staff1 add constraint chk check(dept<100)  4. 到D盤上打開STAFF.TXT文件,把最后一行數據的第三列改為150,這樣該條數據就不滿足第3步加上的檢查約  束條件了,然后用Load命令從文件中裝入數據到staff1表中:  LOAD FROM D:STAFF.TXT OF DEL INSERT INTO STAFF1  5. 此時運行查詢命令:  Select * from staff1  會得到錯誤信息:  SQL0668N 由于表 "USER.STAFF1" 上的原因代碼 "1",所以不答應操作。  SQLSTATE=57016  原因是裝入時有數據違反了檢查約束,造成表處于檢查掛起狀態?! ?. 解除表的檢查掛起狀態,使用:  set integrity for staff1 check immediate unchecked  再次運行查詢命令:  Select * from staff1  發現表可以正常使用了,其中的違反檢查規則的數據也存在?! ±盒阅芤蛩亍 ≡趶奈募虮韺霐祿臅r候,當數據量非凡大的情況下,裝入命令會明顯體現出優勢,原因是它不像導入命令每次插入一行,并且在每行都要檢查是否滿足約束條件,裝入命令從輸入文件讀出數據構建頁,把這些頁直接寫入數據庫,并且在每一行數據裝入時不判定是否滿足約束,另外裝入命令不寫日志,所有這些因素都導致裝入的效率高于導入。  另外,裝入命令還有一些選項可以控制性能因素:  1. COPY YES/NO和Nonrecoverable  ① Nonrecoverable(不可恢復的):指定裝入操作不可恢復,并且不能由后續的前滾操作恢復。前滾操作忽略事務并且標記正在裝入數據的表為“無效”?! 、?Copy No(默認選項):在這種情況下,假如表所在數據庫的歸檔日志處于啟用狀態,則裝入完成后,表所在的表空間將處于備份掛起狀態,直到數據庫或表空間備份完畢,該表空間才成為可寫表空間。原因是裝入操作造成的變化沒有被記錄,所以要恢復裝入操作完成后發生的故障,備份數據庫或表空間是必要的?! 、?Copy Yes:在這種情況下,假如數據庫的歸檔日志啟用,裝入操作的改變將被保存到磁帶、目錄或TSM服務器,并且表空間將不再處于備份掛起狀態?! ?. Fastparse  該文件類型修飾符用于減少數據檢查次數。它只能用于在數據已知正確的情況下,尤其適用于DEL和ASC類型的文件?! ?. Anyorder  假如SAVECOUNT選項沒有使用,該參數答應不遵照輸入文件中的數據順序進行裝入,在SMP(對稱多處理機)系統上CPU_PARALLELISM選項大于1的時候,該參數會提高裝入的性能?! ?. Data Buffer  該參數用于指定從堆棧分配得到的4K大小的內存頁面的數目,作為裝入的內部緩沖區,指定一個大緩沖區有助于提高裝入的性能。  5. CPU_PARALLELISM  該選項只能用于SMP系統上,可以指示使用多少進程或線程解析、轉換、格式化數據。  6. Disk_Parallelism  該選項指定寫數據到磁盤的進程或線程的數目。 上一頁123456
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
色噜噜亚洲精品中文字幕| 亚洲天堂日韩电影| 欧美大片免费观看| 日韩在线视频观看| 国产欧美一区二区三区在线看| 一区二区av在线| 亚洲小视频在线观看| 国产精品稀缺呦系列在线| 色狠狠久久aa北条麻妃| 中日韩美女免费视频网址在线观看| 亚洲美女免费精品视频在线观看| 日韩在线观看免费网站| 欧美野外猛男的大粗鳮| 色偷偷9999www| 性色av一区二区三区红粉影视| 中文字幕在线观看亚洲| 国产在线视频不卡| 亚洲人成毛片在线播放| 久久人人看视频| 97在线视频免费看| 久久精品国产精品亚洲| 91精品久久久久久久久青青| 精品一区二区三区四区在线| 欧美极品欧美精品欧美视频| 亚洲精品一区二区网址| 91精品国产自产在线| 国产精品色悠悠| 成人性生交大片免费看视频直播| 免费91麻豆精品国产自产在线观看| 中文字幕精品在线| 欧美性猛xxx| 日韩激情av在线免费观看| 国产色婷婷国产综合在线理论片a| 在线成人一区二区| 欧美精品在线观看91| 亚洲色图五月天| 成人中文字幕+乱码+中文字幕| 欧美日韩免费在线观看| 亚洲欧美一区二区精品久久久| 国产精品羞羞答答| 久久久精品中文字幕| 欧美色欧美亚洲高清在线视频| 亚洲天堂av图片| 国产精品欧美日韩| 欧美性xxxxx| 成人精品视频在线| 中文字幕日韩专区| 成人激情视频在线观看| 日韩电影在线观看永久视频免费网站| 精品国产91久久久久久| 91视频国产高清| 国产成人精品在线观看| 欧洲亚洲女同hd| 久久久精品在线观看| 国产精品老女人视频| 91热精品视频| 久久深夜福利免费观看| 久久99久国产精品黄毛片入口| 久久电影一区二区| www亚洲精品| 国产精品日韩在线一区| yw.139尤物在线精品视频| 欧美噜噜久久久xxx| 亚洲最大激情中文字幕| 日韩一区在线视频| 久久中文久久字幕| 精品国内产的精品视频在线观看| 亚洲男人天堂久| 欧美久久精品一级黑人c片| 精品国模在线视频| 日韩精品在线视频美女| 国产精品69精品一区二区三区| 国模gogo一区二区大胆私拍| 亚洲第一男人天堂| 亚洲风情亚aⅴ在线发布| 国产91久久婷婷一区二区| 韩国精品美女www爽爽爽视频| 欧美色视频日本高清在线观看| 欧美裸体xxxx极品少妇| 欧美激情aaaa| 欧美精品精品精品精品免费| 欧美日韩成人黄色| 日韩一中文字幕| 97成人精品视频在线观看| 国产伦精品一区二区三区精品视频| 欧美日韩国产中文字幕| 亚洲肉体裸体xxxx137| 亚洲自拍小视频| 国产精品久久9| 欧美一级大片在线免费观看| 欧美精品做受xxx性少妇| 欧美亚洲国产日本| 美女精品久久久| 欧美高跟鞋交xxxxxhd| 国外成人性视频| 91色在线视频| 亚洲欧美日韩国产成人| 久久久久久久久久久久久久久久久久av| 午夜精品蜜臀一区二区三区免费| 欧美精品久久久久久久| 国产在线精品一区免费香蕉| 欧美精品久久久久久久| 狠狠躁夜夜躁人人躁婷婷91| 国产精品对白刺激| 亚洲人成电影在线观看天堂色| 性色av一区二区咪爱| 成人中文字幕+乱码+中文字幕| 亚洲人午夜精品| 国产日韩欧美夫妻视频在线观看| 亚洲网站在线看| 亚洲精品视频久久| 成人黄色在线免费| 91网站免费看| 国产a级全部精品| 精品亚洲一区二区三区在线观看| 国内精品小视频| 97精品国产97久久久久久| 国产精品第七十二页| 欧美一级片久久久久久久| 国产亚洲一区二区精品| 欧美国产日韩二区| 欧美成人激情图片网| 欧美一级免费看| 国产大片精品免费永久看nba| 久久中文字幕在线视频| 日本国产欧美一区二区三区| 亚洲片国产一区一级在线观看| 在线观看日韩www视频免费| 久久精品99无色码中文字幕| 国产成人精品优优av| 日韩成人av在线播放| 精品久久久香蕉免费精品视频| 92国产精品视频| 国产999在线| 日韩女优人人人人射在线视频| 91久久精品久久国产性色也91| 国产区精品视频| 国产亚洲视频中文字幕视频| 日韩精品日韩在线观看| 久久精品成人动漫| 98精品在线视频| 亚洲剧情一区二区| 亚洲国产精品久久久久秋霞蜜臀| 久久夜色精品国产欧美乱| 欧美高清不卡在线| 欧美激情亚洲国产| 欧美极品美女视频网站在线观看免费| 日韩一区二区三区xxxx| 日韩av中文字幕在线免费观看| 色爱av美腿丝袜综合粉嫩av| 精品亚洲一区二区三区在线播放| www.99久久热国产日韩欧美.com| 欧美国产在线视频| 911国产网站尤物在线观看| 国产成人avxxxxx在线看| 国产精品久久久久久一区二区| 精品国产91乱高清在线观看| 欧美性猛交xxxx富婆弯腰| 亚洲美女又黄又爽在线观看| 992tv在线成人免费观看| 成人看片人aa| 亚洲另类图片色| 亚洲成人精品在线| 黑人极品videos精品欧美裸|