時間:2015-06-28 00:00:00 來源:IT貓撲網(wǎng) 作者:網(wǎng)管聯(lián)盟 我要評論(0)
前幾天在工作中不小心truncate了一個表, 而該表中的數(shù)據(jù)又是很重要的數(shù)據(jù)。并且該表數(shù)據(jù)又沒有備份的,有備份的也不是最新的,一時之間不知如何是好。在網(wǎng)上找了很多資料,但沒有一個很適合的,有適合的但又沒詳細(xì)說明,很無奈。經(jīng)過多方面的查找,以下是我綜合網(wǎng)上的資料,成功恢復(fù)表數(shù)據(jù)的詳細(xì)步驟,供大家參考。以便遇到同樣的問題,可以很好的恢復(fù)。
1、首先下載odu數(shù)據(jù)恢復(fù)工具,然后解壓。(odu工具見附件)
2、查詢數(shù)據(jù)文件路徑相關(guān)信息:select ts#,file#,rfile#,name,BLOCK_SIZE from v$datafile;
將其結(jié)構(gòu)填入odu目錄下的control.txt文件中
格式如下:
#ts #fno?? #rfno???? filename????? block_size
0??? 1??? 1 /bbdata/hzdb/system01.dbf? 8192
1??? 2??? 2 /bbidx/hzdb/undotbs01.dbf? 8192
3??? 3??? 3 /bbidx/hzdb/indx01.dbf???? 8192
4??? 4??? 4 /bbdata/hzdb/tools01.dbf?? 8192
5??? 5??? 5 /bbdata/hzdb/users01.dbf?? 8192
6??? 6??? 6 /bbdata/hzdb/REPORT.dbf??? 8192
7??? 7??? 7 /bbdata/hzdb/RESERVE.dbf?? 8192
8??? 8??? 8 /bbdata/hzdb/WZHTBS.dbf??? 8192
9??? 9??? 9 /bbdata/hzdb/perfstat01.dbf????? 8192
3、打開oud
4、執(zhí)行命令:unload dict
5、執(zhí)行命令:scan extent (需等一會兒時間)
6、執(zhí)行命令:desc [用戶名].[被刪除數(shù)據(jù)的表名]
Object ID:33547
Storage(Obj#=33547 DataObj#=33549 TS#=11 File#=10 Block#=1400 Cluster=0)
NO. SEG INT Column Name Null? Type
--- --- --- ------------------------------ --------- ------------------------------
1 1 1 OWNER VARCHAR2(30)
2 2 2 OBJECT_NAME VARCHAR2(128)
3 3 3 SUBOBJECT_NAME VARCHAR2(30)
4 4 4 OBJECT_ID NUMBER
5 5 5 DATA_OBJECT_ID NUMBER
6 6 6 OBJECT_TYPE VARCHAR2(18)
7 7 7 CREATED DATE
8 8 8 LAST_DDL_TIME DATE
9 9 9 TIMESTAMP VARCHAR2(19)
10 10 10 STATUS VARCHAR2(7)
11 11 11 TEMPORARY VARCHAR2(1)
12 12 12 GENERATED VARCHAR2(1)
13 13 13 SECONDARY VARCHAR2(1)
從上面的輸出中,我們可以看到,TEST.T1表所在的表空間號為11,數(shù)據(jù)段頭部為10號文件的1400號塊。
我們使用ODU來確定T1表原來的data object id。一般來說,數(shù)據(jù)段的數(shù)據(jù)塊,一般是在段頭后面相鄰的塊中。但是我們可以從段頭來確認(rèn):
ODU> dump datafile 10 block 1400
Block Header:
block type=0×23 (ASSM segment header block)
block format=0×02 (oracle 8 or 9)
block rdba=0×02800578 (file#=10, block#=1400)
scn=0×0000.00286f2d, seq=4, tail=0×6f2d2304
block checksum value=0×0=0, flag=0
Data Segment Header:
Extent Control Header
-------------------------------------------------------------
Extent Header:: extents: 1 blocks: 5
last map: 0×00000000 #maps: 0 offset: 668
Highwater:: 0×02800579 (rfile#=10,block#=1401)
ext#: 0 blk#: 3 ext size:5
#blocks in seg. hdr’s freelists: 0
#blocks below: 0
mapblk: 0×00000000 offset: 0
--------------------------------------------------------
Low HighWater Mark :
Highwater:: 0×02800579 ext#: 0 blk#: 3 ext size: 5
#blocks in seg. hdr’s freelists: 0
#blocks below: 0
mapblk 0×00000000 offset: 0
關(guān)鍵詞標(biāo)簽:oracle,數(shù)據(jù)恢復(fù)
相關(guān)閱讀
熱門文章 Oracle中使用alter table來增加,刪除,修改列的語法 oracle中使用SQL語句修改字段類型-oracle修改SQL語句案例 誤刪Oracle數(shù)據(jù)庫實例的控制文件 為UNIX服務(wù)器設(shè)置Oracle全文檢索
人氣排行 oracle中使用SQL語句修改字段類型-oracle修改SQL語句案例 Oracle中使用alter table來增加,刪除,修改列的語法 ORACLE SQL 判斷字符串是否為數(shù)字的語句 ORACLE和SQL語法區(qū)別歸納(1) oracle grant 授權(quán)語句 ORACLE修改IP地址后如何能夠使用 如何加速Oracle大批量數(shù)據(jù)處理 Oracle刪除表的幾種方法