<dfn id="w48us"></dfn><ul id="w48us"></ul>
  • <ul id="w48us"></ul>
  • <del id="w48us"></del>
    <ul id="w48us"></ul>
  • oracle中truncatetable后的數據如何恢復

    時間:2024-07-30 16:18:52 Oracle認證 我要投稿
    • 相關推薦

    oracle中truncatetable后的數據如何恢復

      Oracle認證是由Oracle公司,為能夠滿足對Oracle核心人士需求,Oracle公司頒布并實施的一項權威品的服務與支持。下面小編為大家整理了關于oracle中truncatetable后的數據如何恢復的文章,一起來看看吧:

      1、首先下載odu數據恢復工具,然后解壓。(odu工具見附件)

      2、查詢數據文件路徑相關信息:select ts#,file#,rfile#,name,BLOCK_SIZE from v$datafile;

      將其結構填入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、執行命令: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:\ODU\data>sqlldr 用戶名/密碼@數據庫id control=TEST_T1.ctl

    【oracle中truncatetable后的數據如何恢復】相關文章:

    oracle數據庫基本語句02-08

    Oracle數據庫認證層次08-29

    金蝶軟件如何做好數據的備份與恢復11-29

    Oracle數據庫SELECT語句10-25

    Oracle數據庫語句大全12-21

    ORACLE數據字典的有效利用08-24

    word表格中的數據如何排序02-21

    oracle數據庫基礎知識01-21

    Oracle 數據庫查詢小技巧10-17

    oracle數據庫培訓課程大綱08-07

    主站蜘蛛池模板: 精品国产亚洲男女在线线电影 | 亚洲精品A在线观看| 国产精品成熟老女人视频| 麻豆国产高清精品国在线| 欧美精品免费线视频观看视频| 四虎成人精品永久免费AV| 久久97久久97精品免视看秋霞| 国产福利91精品一区二区三区| 亚洲精品制服丝袜四区| 久久久精品波多野结衣| 中文字幕精品视频| 国产精品原创巨作av女教师| 正在播放酒店精品少妇约| 精品乱子伦一区二区三区| 夜色www国产精品资源站| 2021国产精品视频| 人妻少妇乱子伦精品| 污污网站国产精品白丝袜| 国内精品99亚洲免费高清| 欧美精品一区二区三区视频| 国产成人精品久久免费动漫| 国产午夜精品免费一区二区三区| 亚洲精品无码久久久久去q| 老司机精品影院91| 国产精品hd免费观看| 日韩精品一区二区三区大桥未久| 3D动漫精品一区二区三区| 精品无码av一区二区三区| 永久无码精品三区在线4| 人妻少妇精品久久| 欧美精品在线免费| 久久无码精品一区二区三区| 久久精品成人一区二区三区| 国产精品超碰12396| 91精品婷婷国产综合久久| 久久99国产精品久久99| 国产精品视频一区国模私拍| 国产精品臀控福利在线观看| 精品三级在线观看| 国产精品久久久久久福利漫画| 2021精品国产综合久久|