oracle中truncatetable後的數據如何恢復
Oracle認證是由Oracle公司,為能夠滿足對Oracle核心人士需求,Oracle公司頒佈並實施的一項權威品的服務與支持。下面小編為大家整理了關於oracle中truncatetable後的數據如何恢復的文章,一起來看看吧:
1、首先下載odu數據恢復工具,然後解壓。(odu工具見附件)
2、查詢數據文件路徑相關信息:select ts#,file#,rfile#,name,BLOCK_SIZE from v$datafile;
將其結構填入odu目錄下的文件中
格式如下:
#ts #fno #rfno filename block_size
0 1 1 /bbdata/hzdb/ 8192
1 2 2 /bbidx/hzdb/ 8192
3 3 3 /bbidx/hzdb/ 8192
4 4 4 /bbdata/hzdb/ 8192
5 5 5 /bbdata/hzdb/ 8192
6 6 6 /bbdata/hzdb/ 8192
7 7 7 /bbdata/hzdb/ 8192
8 8 8 /bbdata/hzdb/ 8192
9 9 9 /bbdata/hzdb/ 8192
3、打開oud
4、執行命令:unload dict
5、執行命令:scan extent (需等一會兒時間)
6、執行命令:desc [用户名].[被刪除數據的表名]
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,數據段頭部為10號文件的'1400號塊。
我們使用ODU來確定T1表原來的data object id。一般來説,數據段的數據塊,一般是在段頭後面相鄰的塊中。但是我們可以從段頭來確認:
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
Level 1 BMB for High HWM block: 0×02800576
Level 1 BMB for Low HWM block: 0×02800576
--------------------------------------------------------
Segment Type: 1 nl2: 1 blksz: 2048 fbsz: 0
L2 Array start offset: 0×00000434
First Level 3 BMB: 0×00000000
L2 Hint for inserts: 0×02800577
Last Level 1 BMB: 0×02800576
Last Level 1I BMB: 0×02800577
Last Level 1II BMB: 0×00000000
Map Header:: next 0×00000000 #extents: 1 obj#: 33549 flag: 0×220000000
Extent Map
-------------------------------------------------------------
0×02800576 length: 5
Auxillary Map
-------------------------------------------------------------
Extent 0 : L1 dba: 0×02800576 Data dba: 0×02800579
-------------------------------------------------------------
Second Level Bitmap block DBAs
-------------------------------------------------------------
DBA 1: 0×02800577
從上面的輸出中的“Extent 0 : L1 dba: 0×02800576 Data dba: 0×02800579”可以看到,段的第1個數據塊的RDBA為0×02800579,也就是10號文件的1401塊。
我們dump第10號文件的1401塊頭,來得到表T1原來的data object id:
ODU> dump datafile 10 block 1401 header
Block Header:
block type=0×06 (table/index/cluster segment data block)
block format=0×02 (oracle 8 or 9)
block rdba=0×02800579 (file#=10, block#=1401)
scn=0×0000.00285f2b, seq=2, tail=0×5f2b0602
block checksum value=0×0=0, flag=0
Data Block Header Dump:
Object id on Block? Y
seg/obj: 0×830b=33547 csc: 0×00.285f21 itc: 3 flg: E typ: 1 (data)
brn: 0 bdba: 0×2800576 ver: 0×01
Itl Xid Uba Flag Lck Scn/Fsc
0×01 0xffff.000.00000000 0×00000000.0000.00 C--- 0 scn 0×0000.00285f21
0×02 0×0000.000.00000000 0×00000000.0000.00 ---- 0 fsc 0×0000.00000000
0×03 0×0000.000.00000000 0×00000000.0000.00 ---- 0 fsc 0×0000.00000000
Data Block Dump:
================
flag=0×0 --------
ntab=1
nrow=16
frre=-1
fsbo=0×32
ffeo=0×145
avsp=0×113
tosp=0×113
可以看到,T1表原來的data object id就是33547。
7. 使用ODU來unload數據:
ODU> unload table test.t1 object 33547
8、使用sqlldr導入我們恢復的數據:打開cmd命令,執行E:ODUdata>sqlldr 用户名/密碼@數據庫id control=TEST_
-
oracle數據庫密碼修改設置途徑
一、忘記除SYS、SYSTEM用户之外的用户的登錄密碼。用SYS(或SYSTEM)用户登錄。CONNSYS/PASS_WORDASSYSDBA;使用如下語句修改用户的密碼。ALTERUSERuser_nameIDENTIFIEDBYnewpass;注意:密碼不能全是數字。並且不能是數字開頭。否則會出現:ORA-00988:口令缺失或無效...
-
oracle sysdba級用户的認證方式
經過系統化的實訓,讓這部分人羣能夠迅速掌握Oracle最新的核心技術,並能勝任企業大型數據庫管理、維護、開發工作。下面是小編整理的關於oraclesysdba級用户的認證方式,歡迎大家參考!Oracle對於普通賬户和超級管理員(指sysdba和sysoper)的認證機制不一樣,前者是通過...
-
Oracle重做日誌文件管理技巧
重做日誌文件是Oracle數據庫中一種非常重要的日誌文件,也是其一個很有特色的功能。重做日誌文件會紀錄對於數據庫的任何操作,如利用DML語句或者DDL語句對數據進行更改,或者數據庫管理員對數據庫結構進行更改,都會在重做日誌中進行記錄。可見,當數據被意外的刪除或者...
-
關於sql語句優化的知識
用IN寫出來的SQL的優點是比較容易寫及清晰易懂,這比較適合現代軟件開發的風格。但是用IN的SQL性能總是比較低的,從ORACLE執行的步驟來分析用IN的SQL與不用IN的SQL有以下區別:ORACLE試圖將其轉換成多個表的連接,如果轉換不成功則先執行IN裏面的子查詢,再查詢外層的表...
相關文章
- 如何實現bootstrap jquery dataTable異步ajax刷新表格數據
- Will Robot Take the Place of Men英語作文
- 高中優秀英語作文An Unforgettable Experience
- Covering the ears to steal the bell高中英語作文
- 英語美文閲讀:Kerry: Anti-IS Coalition Could Contribute to B
- 高中生優秀英語作文:Have a break away from electronics
- 人教PEP版國小五年級英語下冊Unit3Myschoolcalender.ALet’stalk
- 英語作文:An unforgettable experience
- Notice about the flea marke國中英語作文
- java如何利用java.net.URLConnection發送HTTP請求