国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術(shù)文章
文章詳情頁

DB2 LOAD命令中COPY NO/COPY的說明(1)

瀏覽:3日期:2023-11-08 08:44:25
內(nèi)容提要主要介紹 DB2 LOAD 命令所提供的 COPY NO/COPY YES/NONRECOVERABLE 選項(xiàng),以及與之相關(guān)的注冊(cè)表變量 DB2_LOAD_COPY_NO_OVERRIDE 的功能和使用方法等。當(dāng) DB2 的數(shù)據(jù)庫啟用了前滾恢復(fù)模式,即將日志由循環(huán)日志方式改為歸檔日志,以便用戶在進(jìn)行恢復(fù)操作時(shí),可在恢復(fù)了數(shù)據(jù)庫或表空間的備份后,再通過前滾歸檔日志中的事務(wù),恢復(fù)數(shù)據(jù)庫備份時(shí)間點(diǎn)之后提交的事務(wù),最大程度的保護(hù)數(shù)據(jù)庫的數(shù)據(jù)。而 DB2 的 LOAD 實(shí)用程序?yàn)閷?shí)現(xiàn)快速導(dǎo)入數(shù)據(jù)的功能,除采用了通過直接向數(shù)據(jù)庫中寫入格式化的數(shù)據(jù)頁裝載數(shù)據(jù),導(dǎo)入過程中不激活觸發(fā)器,不會(huì)檢查參考完整性和表檢查約束當(dāng)?shù)确绞酵猓€最小化了記錄事務(wù)日志的操作。在 LOAD 的 LOAD、BUILD、DELETE 和 INDEX COPY 四個(gè)處理階段中,僅在 DELETE 階段記錄對(duì)每個(gè)刪除事件記日志,即只對(duì)每個(gè)違反唯一約束的行的刪除操作記日志,因此整個(gè) LOAD 操作僅記錄了極少的日志。由于 LOAD 最小化了日志的記錄,有因啟用了前滾恢復(fù)的數(shù)據(jù)庫在恢復(fù)在線備份時(shí)需要?dú)w檔日志的特性,對(duì)于這種數(shù)據(jù)庫的 LOAD 操作,為避免執(zhí)行 LOAD 操作后,表在使用 ROLLFORWARD 命令前滾歸檔日志的過程中因缺少日志而被置為非正常狀態(tài),DB2 為 LOAD 命令提供了如下選項(xiàng):·COPY NO(缺省)·COPY YES·NONREVERABLE為更清楚地說明這些選項(xiàng)的作用,這里將以舉例的方式進(jìn)行說明。而在開始操作之前,首先了解一下 DB2 備份操作所產(chǎn)生的映象文件的形式和命名特點(diǎn):在 UNIX 環(huán)境下是文件的形式:Databasealias.Type.Instancename.Nodename.Catnodename.Timestamp.number在 Windows 環(huán)境下是子目錄及文件的形式: 123456下一頁 Databasealias.TypeInstancenameNode0000Catn0000yyyymmddhhmmss.number而其中的 Type 則因備份類型的不同而不同:0 -- 數(shù)據(jù)庫全備份3 -- 表空間備份4 -- 由 LOAD 操作產(chǎn)生的備份1. 進(jìn)行一次數(shù)據(jù)庫的全備份:首先對(duì)已啟用前滾恢復(fù)模式的 SAMPLE 數(shù)據(jù)庫進(jìn)行一次全備份:E:TEST>db2 backup db sample備份成功。此備份映像的時(shí)間戳記是:20051230174105這時(shí)看到在當(dāng)前目錄下產(chǎn)生了一個(gè) SAMPLE.0 的子目錄,表明產(chǎn)生的是一個(gè)數(shù)據(jù)庫全備份。下面將對(duì)這些現(xiàn)象逐個(gè)予以舉例說明:2. 關(guān)于 COPY NO:在 LOAD 操作結(jié)束時(shí),將表所在的表空間置于“備份暫掛狀態(tài),此時(shí)雖然其中的表可以進(jìn)行 SELECT 操作,但不能進(jìn)行 UPDATE 和 DELETE 操作。為使該表狀態(tài)恢復(fù)正常,除去備份暫掛狀態(tài),必須手動(dòng)對(duì)其表空間執(zhí)行一個(gè) BACKUP 命令。由于該選項(xiàng)為缺省選項(xiàng),假如 LOAD 命令中未指明,則默認(rèn)為使用該選項(xiàng),如:E:TEST>db2 connect to sampleE:TEST>db2 load from staff.del of del insert into staffE:TEST>db2 list tablespaces:表空間標(biāo)識(shí) = 2名稱 = USERSPACE1類型 = 系統(tǒng)治理空間內(nèi)容 = 任何數(shù)據(jù)狀態(tài) = 0x0020具體解釋:備份暫掛:E:TEST>db2 select count(*) from staff1-----------701 條記錄已選擇。E:TEST>db2 update staff set id=335 where id=340DB21034E 該命令被當(dāng)作 SQL 語句來處理,因?yàn)樗皇怯行У?ldquo;命令行處理器命令。在 SQL 處理期間,它返回: 上一頁123456下一頁 SQL0290N 不答應(yīng)存取表空間。 SQLSTATE=55039在手動(dòng)對(duì) USERSPACE1 表空間進(jìn)行一次備份操作后,表空間狀態(tài)將正常,再次嘗試更新操作就會(huì)成功:E:TEST>db2 backup db sample tablespace (userspace1)備份成功。此備份映像的時(shí)間戳記是:20051230184841命令完成后可以在當(dāng)前目錄下看到產(chǎn)生了一個(gè) SAMPLE.3 的子目錄,表明產(chǎn)生的是一個(gè)表空間級(jí)的備份。E:TEST>db2 connect to sampleE:TEST>db2 list tablespaces表空間標(biāo)識(shí) = 2名稱 = USERSPACE1類型 = 系統(tǒng)治理空間內(nèi)容 = 任何數(shù)據(jù)狀態(tài) = 0x0000具體解釋:正常而所產(chǎn)生這份關(guān)于表空間的備份可在數(shù)據(jù)庫因前滾操作將表空間置為“復(fù)原暫掛狀態(tài)時(shí)用于將表空間狀態(tài)恢復(fù)為正常,并恢復(fù) LOAD 操作對(duì)該表的修改。如當(dāng)前滾數(shù)據(jù)庫超過 LOAD 時(shí)間點(diǎn)后,表空間將被置為復(fù)原暫掛狀態(tài):E:TEST>db2 restore db sample taken at 20051230174105DB20000I RESTORE DATABASE 命令成功完成。E:TEST>db2 rollforward db sample to end of logs and stopSQL1271W 已恢復(fù)數(shù)據(jù)庫 "SAMPLE",但在節(jié)點(diǎn) "0"上有一個(gè)或多個(gè)表空間脫機(jī)E:TEST>db2 connect to sampleE:TEST>db2 list tablespaces表空間標(biāo)識(shí) = 2名稱 = USERSPACE1類型 = 系統(tǒng)治理空間內(nèi)容 = 任何數(shù)據(jù)狀態(tài) = 0x0100具體解釋:復(fù)原暫掛此時(shí)可利用這一表空間級(jí)的備份進(jìn)行恢復(fù)操作:E:TEST>db2 restore db sample tablespace (userspace1) taken at 20051230184841DB20000I RESTORE DATABASE 命令成功完成。E:TEST>db2 connect to sampleE:TEST>db2 list tablespaces:表空間標(biāo)識(shí) = 2名稱 = USERSPACE1類型 = 系統(tǒng)治理空間內(nèi)容 = 任何數(shù)據(jù)狀態(tài) = 0x0080具體解釋:前滾暫掛:E:TEST>db2 rollforward db sample to end of logs and stop tablespace (userspace1)前滾狀態(tài)輸入數(shù)據(jù)庫別名 = sample節(jié)點(diǎn)數(shù)已返回狀態(tài) = 1節(jié)點(diǎn)號(hào) = 0前滾狀態(tài) = 未暫掛下一個(gè)要讀取的日志文件 =已處理的日志文件 = -上次落實(shí)的事務(wù) = 2005-12-30-10.47.10.000000DB20000I ROLLFORWARD 命令成功完成。E:TEST>db2 list tablespaces:表空間標(biāo)識(shí) = 2名稱 = USERSPACE1類型 = 系統(tǒng)治理空間內(nèi)容 = 任何數(shù)據(jù)狀態(tài) = 0x0000具體解釋:正常:E:TEST>db2 update staff set id=335 where id=340 上一頁123456下一頁 DB20000I SQL 命令成功完成。可見表空間狀態(tài)已正常,表也可執(zhí)行更新操作了。3. 關(guān)于 COPY YES:在 LOAD 操作結(jié)束時(shí),DB2 自動(dòng)對(duì)表所在的表空間進(jìn)行一次備份操作,因而 LOAD 結(jié)束后,表所在的表空間不會(huì)再處于“備份暫掛狀態(tài),而為“正常狀態(tài)。但由于要進(jìn)行備份操作,所以這種 LOAD 操作的時(shí)間會(huì)較沒有備份的長(zhǎng)。如:E:TEST>db2 connect to sampleE:TEST>db2 load from staff.del of del insert into staff copy yes to .E:TEST>db2 list tablespaces:表空間標(biāo)識(shí) = 2名稱 = USERSPACE1類型 = 系統(tǒng)治理空間內(nèi)容 = 任何數(shù)據(jù)狀態(tài) = 0x0000具體解釋:正常:E:TEST>db2 select count(*) from staff1-----------1051 條記錄已選擇。此時(shí)可在當(dāng)前目錄下看到一個(gè) SAMPLE.4 的子目錄,表明產(chǎn)生的是一個(gè)由 LOAD 操作生成的備份,而這份備份將在數(shù)據(jù)庫進(jìn)行前滾恢復(fù)操作時(shí)用于重新創(chuàng)建 LOAD 操作對(duì)數(shù)據(jù)庫的修改。如:E:TEST>db2 restore db sample taken at 20051230174105DB20000I RESTORE DATABASE 命令成功完成。前滾狀態(tài)輸入數(shù)據(jù)庫別名 = sample節(jié)點(diǎn)數(shù)已返回狀態(tài) = 1節(jié)點(diǎn)號(hào) = 0前滾狀態(tài) = 未暫掛下一個(gè)要讀取的日志文件 =已處理的日志文件 = S0000002.LOG - S0000003.LOG上次落實(shí)的事務(wù) = 2005-12-30-11.48.26.000000DB20000I ROLLFORWARD 命令成功完成。E:TEST>db2 connect to sampleE:TEST>db2 list tablespaces:表空間標(biāo)識(shí) = 2名稱 = USERSPACE1類型 = 系統(tǒng)治理空間內(nèi)容 = 任何數(shù)據(jù)狀態(tài) = 0x0000具體解釋:正常:E:TEST>db2 select count(*) from staff1-----------1051 條記錄已選擇。 上一頁123456下一頁 這表明在 SAMPLE.4 下的備份被用于了前滾恢復(fù)操作,而重新創(chuàng)建了 LOAD 操作對(duì)數(shù)據(jù)庫插入的記錄。4. 關(guān)于 NONRECOVERABLE:該選項(xiàng)會(huì)將 LOAD 操作標(biāo)志為不可恢復(fù),即數(shù)據(jù)庫不能通過后續(xù)的前滾操作而被恢復(fù)。LOAD 操作結(jié)束后,數(shù)據(jù)庫既不會(huì)處于“備份暫掛狀態(tài),也不會(huì)產(chǎn)生任何的備份。E:TEST>db2 connect to sampleE:TEST>db2 load from staff.del of del insert into staff nonrecoverableE:TEST>db2 list tablespaces:表空間標(biāo)識(shí) = 2名稱 = USERSPACE1類型 = 系統(tǒng)治理空間內(nèi)容 = 任何數(shù)據(jù)狀態(tài) = 0x0000具體解釋:正常:雖然 LOAD 之后表空間和表的狀態(tài)都正常,但假如今后需要執(zhí)行前滾命令恢復(fù)數(shù)據(jù)庫時(shí),前滾操作將跳過 LOAD 事務(wù)的處 理,而將 LOAD 的表標(biāo)記為無效,是對(duì)表的任何操作都不能進(jìn)行。如: E:TEST>db2 restore db sample taken at 20051230174105DB20000I RESTORE DATABASE 命令成功完成。E:TEST>db2 rollforward db sample to end of logs and stop前滾狀態(tài)輸入數(shù)據(jù)庫別名 = sample節(jié)點(diǎn)數(shù)已返回狀態(tài) = 1節(jié)點(diǎn)號(hào) = 0前滾狀態(tài) = 未暫掛下一個(gè)要讀取的日志文件 =已處理的日志文件 = S0000002.LOG - S0000003.LOG上次落實(shí)的事務(wù) = 2005-12-30-12.19.55.000000DB20000I ROLLFORWARD 命令成功完成。E:>db2 connect to sampleE:TEST>db2 list tablespaces:表空間標(biāo)識(shí) = 2名稱 = USERSPACE1類型 = 系統(tǒng)治理空間內(nèi)容 = 任何數(shù)據(jù)狀態(tài) = 0x0000具體解釋:正常:E:>db2 select * from staffID NAME DEPT JOB YEARS SALARY COMM------ --------- ------ ----- ------ --------- ---------SQL1477N 不能存取表 "LIWENLI.STAFF"。 SQLSTATE=55019 上一頁123456下一頁 這表明該表已不可操作,此時(shí)只有將表刪除,重新構(gòu)建,或使用 LOAD 操作時(shí)間點(diǎn)之后所做的數(shù)據(jù)庫全備份或表空間備份來恢復(fù)該表。5. 關(guān)于注冊(cè)表變量 DB2_LOAD_COPY_NO_OVERRIDE 的介紹:另外 DB2 還提供了一個(gè)注冊(cè)表變量:DB2_LOAD_COPY_NO_OVERRIDE,可將 LOAD 的缺省選項(xiàng) COPY NO 設(shè)置為 NONRECOVERABLE 或 COPY YES。具體使用方法舉例為:設(shè)置為 COPY YES 的方法:E:TEST>db2set DB2_LOAD_COPY_NO_OVERRIDE="COPY YES TO E:TEST"E:TEST>db2 terminateE:TEST>db2setDB2_LOAD_COPY_NO_OVERRIDE=COPY YES TO E:TEST:E:TEST>db2 load from staff.del of del insert into staffSQL27966W DB2_LOAD_COPY_NO_OVERRIDE注冊(cè)表變量值 "COPY YES TO E:TEST" 將覆蓋在 Load 中指定的 COPY NO 參數(shù)。::設(shè)置為 NONRECOVERABLE 的方法:E:TEST>db2set DB2_LOAD_COPY_NO_OVERRIDE=NONRECOVERABLEE:TEST>db2 terminateE:TEST>db2setDB2_LOAD_COPY_NO_OVERRIDE=NONRECOVERABLE:E:TEST>db2 load from staff.del of del insert into staffSQL27966W DB2_LOAD_COPY_NO_OVERRIDE 注冊(cè)表變量值 "NONRECOVERABLE" 將覆蓋在Load 中指定的 COPY NO 參數(shù)。::通過上述對(duì) LOAD 的 COPY NO,COPY YES 和 NONRECOVERABLE 參數(shù),以及 DB2 注冊(cè)表變量 DB2_LOAD_COPY_NO_OVERRIDE 的具體和舉例說明,到此我們已經(jīng)把握了它們的功能和使用方法。由于 LOAD 操作幾乎不記日志的特性,在對(duì)啟用了前滾恢復(fù)的數(shù)據(jù)庫實(shí)現(xiàn) LOAD 操作時(shí)應(yīng)注重從中選擇適當(dāng)?shù)倪x項(xiàng),以保證執(zhí)行了 LOAD 操作的表的可用性。 上一頁123456
標(biāo)簽: DB2 數(shù)據(jù)庫
主站蜘蛛池模板: 欧美一级毛片特黄大 | 色偷偷资源网 | 日韩毛片在线免费观看 | 久久手机在线视频 | 俄罗斯aaaa一级毛片 | 精品区 | 自拍偷自拍亚洲精品一区 | 日韩美女专区中文字幕 | 孕妇一级片 | 国产精品成人一区二区不卡 | 美国毛片亚洲社区在线观看 | 免费在线一级片 | 欧美精品99| 久久五月女厕所一区二区 | 日本强不卡在线观看 | 欧美日韩精品一区二区视频在线观看 | 欧美精品a毛片免费观看 | 日韩一级片免费在线观看 | 久久久久久网站 | 国产精品漂亮美女在线观看 | 久久亚洲私人国产精品va | 亚洲成a人片在线观看中文 亚洲成a人片在线观看中文!!! | 亚洲午夜在线播放 | 欧美成人毛片一级在线 | 欧美成人h版在线观看 | 国产精品永久免费自在线观看 | 国产精品91在线 | 伊大人香蕉久久网 | 成人亚洲精品 | 日本丶国产丶欧美色综合 | 1204国产成人精品视频 | 亚洲国产精品一区二区不卡 | 亚洲最大看欧美片网站 | 日韩精品毛片 | 日韩毛片在线免费观看 | 成人毛片国产a | 久热香蕉在线视频 | 又黄又湿又爽吸乳视频 | 亚洲特级毛片 | 天天干夜夜怕 | 一级成人毛片免费观看欧美 |