青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

Prayer

在一般中尋求卓越
posts - 1256, comments - 190, trackbacks - 0, articles - 0
  C++博客 :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理
[標(biāo)題] 關(guān)于 DB2 LOAD 命令中 COPY NO/COPY YES/NONRECOVERABLE 選項(xiàng)的說(shuō)明


內(nèi)容提要:


主要介紹 DB2 LOAD 命令所提供的 COPY NO/COPY YES/NONRECOVERABLE 選項(xiàng),以及與之相關(guān)的注冊(cè)表變量 DB2_LOAD_COPY_NO_OVERRIDE 的功能和使用方法等。


說(shuō)明:


當(dāng) DB2 的數(shù)據(jù)庫(kù)啟用了前滾恢復(fù)模式,即將日志由循環(huán)日志方式改為歸檔日志,以便用戶(hù)在進(jìn)行恢復(fù)操作時(shí),可在恢復(fù)了數(shù)據(jù)庫(kù)或表空間的備份后,再通過(guò)前滾歸檔日志中的事務(wù),恢復(fù)數(shù)據(jù)庫(kù)備份時(shí)間點(diǎn)之后提交的事務(wù),最大程度的保護(hù)數(shù)據(jù)庫(kù)的數(shù)據(jù)。

DB2LOAD 實(shí)用程序?yàn)閷?shí)現(xiàn)快速導(dǎo)入數(shù)據(jù)的功能,除采用了通過(guò)直接向數(shù)據(jù)庫(kù)中寫(xiě)入格式化的數(shù)據(jù)頁(yè)裝載數(shù)據(jù),導(dǎo)入過(guò)程中不激活觸發(fā)器,不會(huì)檢查參考完整性和表檢查約束當(dāng)?shù)确绞酵猓€最小化了記錄事務(wù)日志的操作。在 LOADLOAD、BUILD、DELETE 和 INDEX COPY 四個(gè)處理階段中,僅在 DELETE 階段記錄對(duì)每個(gè)刪除事件記日志,即只對(duì)每個(gè)違反唯一約束的行的刪除操作記日志,因此整個(gè) LOAD 操作僅記錄了極少的日志。

由于 LOAD 最小化了日志的記錄,有因啟用了前滾恢復(fù)的數(shù)據(jù)庫(kù)在恢復(fù)在線(xiàn)備份時(shí)需要?dú)w檔日志的特性,對(duì)于這種數(shù)據(jù)庫(kù)的 LOAD 操作,為避免執(zhí)行 LOAD 操作后,表在使用 ROLLFORWARD 命令前滾歸檔日志的過(guò)程中因缺少日志而被置為非正常狀態(tài),DB2LOAD 命令提供了如下選項(xiàng):

·COPY NO(缺省)
·COPY YES
·NONREVERABLE

為更清楚地說(shuō)明這些選項(xiàng)的作用,這里將以舉例的方式進(jìn)行說(shuō)明。而在開(kāi)始操作之前,首先了解一下 DB2 備份操作所產(chǎn)生的映象文件的形式和命名特點(diǎn):

在 UNIX 環(huán)境下是文件的形式:
Databasealias.Type .Instancename.Nodename.Catnodename.Timestamp.number

在 Windows 環(huán)境下是子目錄及文件的形式:
Databasealias.Type \Instancename\Node0000\Catn0000\yyyymmdd\hhmmss.number

而其中的 Type 則因備份類(lèi)型的不同而不同:

0 -- 數(shù)據(jù)庫(kù)全備份
3 -- 表空間備份
4 -- 由 LOAD 操作產(chǎn)生的備份


1. 進(jìn)行一次數(shù)據(jù)庫(kù)的全備份:

首先對(duì)已啟用前滾恢復(fù)模式的 SAMPLE 數(shù)據(jù)庫(kù)進(jìn)行一次全備份:

E:\TEST>db2 backup db sample
備份成功。此備份映像的時(shí)間戳記是:20051230174105

這時(shí)看到在當(dāng)前目錄下產(chǎn)生了一個(gè) SAMPLE.0 的子目錄,表明產(chǎn)生的是一個(gè)數(shù)據(jù)庫(kù)全備份。下面將對(duì)這些現(xiàn)象逐個(gè)予以舉例說(shuō)明:


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 sample

E:\TEST>db2 load from staff.del of del insert into staff

E:\TEST>db2 list tablespaces


表空間標(biāo)識(shí) = 2
名稱(chēng) = USERSPACE1
類(lèi)型 = 系統(tǒng)管理空間
內(nèi)容 = 任何數(shù)據(jù)
狀態(tài) = 0x0020
詳細(xì)解釋?zhuān)?br>備份暫掛


E:\TEST>db2 select count(*) from staff
1
-----------
70
1 條記錄已選擇。

E:\TEST>db2 update staff set id=335 where id=340
DB21034E 該命令被當(dāng)作 SQL 語(yǔ)句來(lái)處理,因?yàn)樗皇怯行У?font face="Times New Roman">“ 命令行處理器 命令。在 SQL 處理期間,它返回:
SQL0290N 不允許存取表空間。 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 sample

E:\TEST>db2 list tablespaces

表空間標(biāo)識(shí) = 2
名稱(chēng) = USERSPACE1
類(lèi)型 = 系統(tǒng)管理空間
內(nèi)容 = 任何數(shù)據(jù)
狀態(tài) = 0x0000
詳細(xì)解釋?zhuān)?br>正常

而所產(chǎn)生這份關(guān)于表空間的備份可在數(shù)據(jù)庫(kù)因前滾操作將表空間置為“復(fù)原暫掛”狀態(tài)時(shí)用于將表空間狀態(tài)恢復(fù)為正常,并恢復(fù) LOAD 操作對(duì)該表的修改。如當(dāng)前滾數(shù)據(jù)庫(kù)超過(guò) LOAD 時(shí)間點(diǎn)后,表空間將被置為復(fù)原暫掛狀態(tài):

E:\TEST>db2 restore db sample taken at 20051230174105
DB20000I RESTORE DATABASE 命令成功完成。

E:\TEST>db2 rollforward db sample to end of logs and stop
SQL1271W 已恢復(fù)數(shù)據(jù)庫(kù) "SAMPLE",但在節(jié)點(diǎn) "0"上有一個(gè)或多個(gè)表空間脫機(jī)

E:\TEST>db2 connect to sample

E:\TEST>db2 list tablespaces
表空間標(biāo)識(shí) = 2
名稱(chēng) = USERSPACE1
類(lèi)型 = 系統(tǒng)管理空間
內(nèi)容 = 任何數(shù)據(jù)
狀態(tài) = 0x0100
詳細(xì)解釋?zhuān)?br>復(fù)原暫掛

此時(shí)可利用這一表空間級(jí)的備份進(jìn)行恢復(fù)操作:

E:\TEST>db2 restore db sample tablespace (userspace1) taken at 20051230184841
DB20000I RESTORE DATABASE 命令成功完成。

E:\TEST>db2 connect to sample

E:\TEST>db2 list tablespaces

表空間標(biāo)識(shí) = 2
名稱(chēng) = USERSPACE1
類(lèi)型 = 系統(tǒng)管理空間
內(nèi)容 = 任何數(shù)據(jù)
狀態(tài) = 0x0080
詳細(xì)解釋?zhuān)?br>前滾暫掛


E:\TEST>db2 rollforward db sample to end of logs and stop tablespace (userspace1)

前滾狀態(tài)

輸入數(shù)據(jù)庫(kù)別名 = 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.000000

DB20000I ROLLFORWARD 命令成功完成。

E:\TEST>db2 connect to sample

E:\TEST>db2 list tablespaces
:
表空間標(biāo)識(shí) = 2
名稱(chēng) = USERSPACE1
類(lèi)型 = 系統(tǒng)管理空間
內(nèi)容 = 任何數(shù)據(jù)
狀態(tài) = 0x0000
詳細(xì)解釋?zhuān)?br>正常
:

E:\TEST>db2 update staff set id=335 where id=340
DB20000I SQL 命令成功完成。

可見(jiàn)表空間狀態(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ì)較沒(méi)有備份的長(zhǎng)。如:

E:\TEST>db2 connect to sample

E:\TEST>db2 load from staff.del of del insert into staff copy yes to .

E:\TEST>db2 list tablespaces
:
表空間標(biāo)識(shí) = 2
名稱(chēng) = USERSPACE1
類(lèi)型 = 系統(tǒng)管理空間
內(nèi)容 = 任何數(shù)據(jù)
狀態(tài) = 0x0000
詳細(xì)解釋?zhuān)?br>正常
:

E:\TEST>db2 select count(*) from staff
1
-----------
105
1 條記錄已選擇。


此時(shí)可在當(dāng)前目錄下看到一個(gè) SAMPLE.4 的子目錄,表明產(chǎn)生的是一個(gè)由 LOAD 操作生成的備份,而這份備份將在數(shù)據(jù)庫(kù)進(jìn)行前滾恢復(fù)操作時(shí)用于重新創(chuàng)建 LOAD 操作對(duì)數(shù)據(jù)庫(kù)的修改。如:

E:\TEST>db2 restore db sample taken at 20051230174105
DB20000I RESTORE DATABASE 命令成功完成。

E:\TEST>db2 rollforward db sample to end of logs and stop

前滾狀態(tài)

輸入數(shù)據(jù)庫(kù)別名 = 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.000000

DB20000I ROLLFORWARD 命令成功完成。

E:\TEST>db2 connect to sample

E:\TEST>db2 list tablespaces
:
表空間標(biāo)識(shí) = 2
名稱(chēng) = USERSPACE1
類(lèi)型 = 系統(tǒng)管理空間
內(nèi)容 = 任何數(shù)據(jù)
狀態(tài) = 0x0000
詳細(xì)解釋?zhuān)?br>正常
:

E:\TEST>db2 select count(*) from staff
1
-----------
105
1 條記錄已選擇。

這表明在 SAMPLE.4 下的備份被用于了前滾恢復(fù)操作,而重新創(chuàng)建了 LOAD 操作對(duì)數(shù)據(jù)庫(kù)插入的記錄。


4. 關(guān)于 NONRECOVERABLE

該選項(xiàng)會(huì)將 LOAD 操作標(biāo)志為不可恢復(fù),即數(shù)據(jù)庫(kù)不能通過(guò)后續(xù)的前滾操作而被恢復(fù)。LOAD 操作結(jié)束后,數(shù)據(jù)庫(kù)既不會(huì)處于“備份暫掛”狀態(tài),也不會(huì)產(chǎn)生任何的備份。

E:\TEST>db2 connect to sample

E:\TEST>db2 load from staff.del of del insert into staff nonrecoverable

E:\TEST>db2 list tablespaces
:
表空間標(biāo)識(shí) = 2
名稱(chēng) = USERSPACE1
類(lèi)型 = 系統(tǒng)管理空間
內(nèi)容 = 任何數(shù)據(jù)
狀態(tài) = 0x0000
詳細(xì)解釋?zhuān)?br>正常
:

雖然 LOAD 之后表空間和表的狀態(tài)都正常,但如果今后需要執(zhí)行前滾命令恢復(fù)數(shù)據(jù)庫(kù)時(shí),前滾操作將跳過(guò) LOAD 事務(wù)的處理,而將 LOAD 的表標(biāo)記為無(wú)效,是對(duì)表的任何操作都不能進(jìn)行。如:

E:\TEST>db2 restore db sample taken at 20051230174105
DB20000I RESTORE DATABASE 命令成功完成。

E:\TEST>db2 rollforward db sample to end of logs and stop

前滾狀態(tài)

輸入數(shù)據(jù)庫(kù)別名 = 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.000000

DB20000I ROLLFORWARD 命令成功完成。

E:\>db2 connect to sample

E:\TEST>db2 list tablespaces
:
表空間標(biāo)識(shí) = 2
名稱(chēng) = USERSPACE1
類(lèi)型 = 系統(tǒng)管理空間
內(nèi)容 = 任何數(shù)據(jù)
狀態(tài) = 0x0000
詳細(xì)解釋?zhuān)?br>正常
:

E:\>db2 select * from staff

ID NAME DEPT JOB YEARS SALARY COMM
------ --------- ------ ----- ------ --------- ---------
SQL1477N 不能存取表 "LIWENLI.STAFF"。 SQLSTATE=55019

這表明該表已不可操作,此時(shí)只有將表刪除,重新構(gòu)建,或使用 LOAD 操作時(shí)間點(diǎn)之后所做的數(shù)據(jù)庫(kù)全備份或表空間備份來(lái)恢復(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 terminate
E:\TEST>db2set
DB2_LOAD_COPY_NO_OVERRIDE=COPY YES TO E:\TEST
:

E:\TEST>db2 load from staff.del of del insert into staff
SQL27966W 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=NONRECOVERABLE
E:\TEST>db2 terminate
E:\TEST>db2set
DB2_LOAD_COPY_NO_OVERRIDE=NONRECOVERABLE
:

E:\TEST>db2 load from staff.del of del insert into staff
SQL27966W DB2_LOAD_COPY_NO_OVERRIDE 注冊(cè)表變量值 "NONRECOVERABLE" 將覆蓋在Load 中指定的 COPY NO 參數(shù)。
:
:


通過(guò)上述對(duì) LOAD 的 COPY NO,COPY YES 和 NONRECOVERABLE 參數(shù),以及 DB2 注冊(cè)表變量 DB2_LOAD_COPY_NO_OVERRIDE 的詳細(xì)和舉例說(shuō)明,到此我們已經(jīng)掌握了它們的功能和使用方法。由于 LOAD 操作幾乎不記日志的特性,在對(duì)啟用了前滾恢復(fù)的數(shù)據(jù)庫(kù)實(shí)現(xiàn) LOAD 操作時(shí)應(yīng)注意從中選擇適當(dāng)?shù)倪x項(xiàng),以保證執(zhí)行了 LOAD 操作的表的可用性。


參考資料:
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            国产精品高清在线观看| 亚洲一区二区日本| 免费成人网www| 久久久久久久国产| 久久国产精品高清| 久久国产精品99精品国产| 久久精品一区二区三区不卡牛牛| 亚洲欧美日韩国产中文在线| 亚洲欧美国产毛片在线| 亚洲影院在线观看| 午夜影院日韩| 久久成人精品无人区| 欧美亚洲免费高清在线观看| 久久国产精品网站| 久久久久在线观看| 蜜月aⅴ免费一区二区三区| 免费短视频成人日韩| 欧美激情精品久久久久久变态| 亚洲国产视频a| 欧美顶级少妇做爰| 亚洲日本黄色| 亚洲天堂男人| 久久av一区二区| 久久精品99无色码中文字幕| 亚洲精品一区二区三区av| 亚洲高清视频的网址| 亚洲大片一区二区三区| 亚洲美女av黄| 在线一区二区三区四区| 久久成人综合网| 欧美成年人在线观看| 日韩亚洲欧美成人一区| 香蕉精品999视频一区二区| 久久久水蜜桃| 欧美日韩国产一区| 国产精品亚洲不卡a| 国内精品99| 99精品视频免费观看| 香蕉亚洲视频| 麻豆精品在线视频| 亚洲美女淫视频| 小辣椒精品导航| 欧美风情在线| 国产老女人精品毛片久久| 亚洲高清不卡av| 99精品视频网| 久久国产夜色精品鲁鲁99| 久久综合亚州| 一本大道av伊人久久综合| 久久精品三级| 欧美aaa级| 国产日韩欧美日韩大片| 亚洲日本中文字幕| 欧美专区18| 亚洲人成7777| 亚洲欧美制服中文字幕| 欧美国产日韩视频| 国产午夜精品美女视频明星a级| 亚洲片区在线| 欧美成在线观看| 欧美在线播放一区| 欧美视频在线看| 狠狠噜噜久久| 亚洲一品av免费观看| 老巨人导航500精品| 一区二区三区欧美视频| 西西人体一区二区| 欧美偷拍一区二区| 亚洲片在线资源| 久久天堂精品| 亚洲无毛电影| 欧美日本国产精品| 亚洲国产精品成人综合色在线婷婷| 亚洲影院免费| 欧美激情亚洲另类| 久久久国际精品| 国产欧美一区二区三区久久人妖| 亚洲精品综合在线| 欧美jjzz| 久久激情中文| 国产午夜久久久久| 午夜激情综合网| 99香蕉国产精品偷在线观看| 欧美福利精品| 亚洲高清成人| 蜜乳av另类精品一区二区| 欧美亚洲一区三区| 国产精品分类| 一区二区三区www| 亚洲国产日韩欧美一区二区三区| 久久精品国产999大香线蕉| 国产伦精品一区二区三区视频黑人 | 制服丝袜亚洲播放| 欧美人与性动交cc0o| 亚洲黄色一区| 欧美国产日本在线| 老司机免费视频久久| 激情综合中文娱乐网| 久久激情网站| 亚洲欧美制服中文字幕| 国产亚洲福利| 久久精品最新地址| 久久成人免费| 国产日韩高清一区二区三区在线| 亚洲视频在线观看| 亚洲免费成人av| 欧美三级小说| 亚洲图片在区色| 久久精品国产第一区二区三区| 国产三级欧美三级| 久久免费国产| 久久国产精彩视频| 一区二区三区在线免费视频| 麻豆精品一区二区av白丝在线| 狂野欧美一区| 亚洲精品小视频在线观看| 欧美成人激情视频| 欧美粗暴jizz性欧美20| 亚洲每日更新| 亚洲香蕉网站| 国产一区二区激情| 欧美 日韩 国产精品免费观看| 麻豆精品国产91久久久久久| 亚洲人成在线观看网站高清| 亚洲精选91| 欧美三级视频在线播放| 香蕉av777xxx色综合一区| 欧美一二三区精品| 在线日韩av片| 亚洲精品久久| 国产精品视频一| 欧美在线啊v一区| 久久婷婷一区| aaa亚洲精品一二三区| 中文在线资源观看网站视频免费不卡| 国产精品尤物福利片在线观看| 久久婷婷综合激情| 欧美精品在线观看91| 午夜精品婷婷| 老司机精品久久| 中文国产亚洲喷潮| 亚洲在线一区二区| 在线免费精品视频| 亚洲精品色婷婷福利天堂| 欧美日韩成人精品| 久久精品二区三区| 久久人人97超碰国产公开结果 | 午夜精品一区二区三区在线| 欧美一区二区三区四区高清| 亚洲精品国产精品国自产在线| 亚洲精品一二区| 国内成人自拍视频| 亚洲肉体裸体xxxx137| 国产精品久久久久99| 久久网站免费| 欧美日韩xxxxx| 久久久久国色av免费看影院| 麻豆乱码国产一区二区三区| 国产精品99久久久久久www| 欧美一级淫片aaaaaaa视频| 亚洲黄色成人久久久| 日韩网站免费观看| 国内综合精品午夜久久资源| 日韩视频一区二区三区| 欧美亚洲在线播放| 午夜日韩视频| 9色国产精品| 久久久久久有精品国产| 亚洲免费一级电影| 欧美福利电影网| 久久亚洲国产精品一区二区| 欧美午夜片欧美片在线观看| 欧美国产丝袜视频| 国产欧美综合在线| 99国产精品视频免费观看一公开| 国内精品伊人久久久久av一坑| 亚洲精品日韩综合观看成人91| 红桃视频国产精品| 亚洲免费在线视频一区 二区| 亚洲电影激情视频网站| 欧美亚洲视频一区二区| 亚洲天堂免费观看| 另类国产ts人妖高潮视频| 亚洲系列中文字幕| 欧美大片免费观看在线观看网站推荐| 欧美在线视屏| 国产精品久久久免费| 91久久夜色精品国产九色| 亚洲福利国产| 久久精品女人的天堂av| 亚洲女人小视频在线观看| 欧美日韩1区2区| 欧美国产成人精品| 国产一区二区三区四区三区四| 亚洲淫片在线视频| 中文在线一区| 欧美精品尤物在线| 亚洲国产免费看| 亚洲欧洲日产国产综合网| 老司机免费视频一区二区|