• 学习笔记:Oracle dul数据挖掘 使用DUL数据恢复软件恢复分区表中


    使用Oracle dul数据恢复工具对Oracle数据库分区表中的数据进行恢复

    创建SALES分区表案例

    CREATE TABLE SALES 
    ( 
      PRODUCT_ID VARCHAR2(5), 
      SALES_DATE DATE, 
      SALES_COST NUMBER(10), 
      STATUS VARCHAR2(20) 
    ) 
    PARTITION BY RANGE(SALES_DATE) 
      SUBPARTITION BY LIST (STATUS) 
      SUBPARTITION TEMPLATE 
      ( 
        SUBPARTITION SUB1 VALUES ('ACTIVE') , 
        SUBPARTITION SUB2 VALUES ('INACTIVE') 
      ) 
    ( 
      PARTITION P1 VALUES LESS THAN (TO_DATE('2003-01-01','YYYY-MM-DD')), 
      PARTITION P2 VALUES LESS THAN (TO_DATE('2003-03-01','YYYY-MM-DD'))
    ) 
    /
    INSERT INTO SALES VALUES('00001','01-Jan-02',100,'ACTIVE') 
    / 
    INSERT INTO SALES VALUES('00002','01-Jan-01',200,'ACTIVE') 
    / 
    INSERT INTO SALES VALUES('00003','01-Feb-03',300,'INACTIVE') 
    / 
    INSERT INTO SALES VALUES('00004','04-Feb-03',300,'INACTIVE') 
    / 
    INSERT INTO SALES VALUES('00005','04-Feb-02',300,'INACTIVE') 
    / 
    

    查询结果

    SQL> select * from sales;
    
    PRODU SALES_DATE   SALES_COST STATUS
    ----- ------------ ---------- --------------------
    00001 01-JAN-02           100 ACTIVE
    00002 01-JAN-01           200 ACTIVE
    00005 04-FEB-02           300 INACTIVE
    00003 01-FEB-03           300 INACTIVE
    00004 04-FEB-03           300 INACTIVE
    
    SQL> select  * from sales PARTITION(p1);
    
    PRODU SALES_DATE   SALES_COST STATUS
    ----- ------------ ---------- --------------------
    00001 01-JAN-02           100 ACTIVE
    00002 01-JAN-01           200 ACTIVE
    00005 04-FEB-02           300 INACTIVE
    
    SQL> select  * from sales PARTITION(p2);
    
    PRODU SALES_DATE   SALES_COST STATUS
    ----- ------------ ---------- --------------------
    00003 01-FEB-03           300 INACTIVE
    00004 04-FEB-03           300 INACTIVE
    
    SQL> select  * from sales SUBPARTITION(p1_sub1);
    
    PRODU SALES_DATE   SALES_COST STATUS
    ----- ------------ ---------- --------------------
    00001 01-JAN-02           100 ACTIVE
    00002 01-JAN-01           200 ACTIVE
    
    SQL> select  * from sales SUBPARTITION(p1_sub2);
    
    PRODU SALES_DATE   SALES_COST STATUS
    ----- ------------ ---------- --------------------
    00005 04-FEB-02           300 INACTIVE
    
    SQL> select  * from sales SUBPARTITION(p2_sub1);
    
    no rows selected
    
    SQL> select  * from sales SUBPARTITION(p2_sub2);
    
    PRODU SALES_DATE   SALES_COST STATUS
    ----- ------------ ---------- --------------------
    00003 01-FEB-03           300 INACTIVE
    00004 04-FEB-03           300 INACTIVE
    

    启动dul

    [oracle@xifenfei dul]$ ./dul
    
    Data UnLoader: 10.2.0.5.20 - Internal Only - on Sat Jan 19 17:37:45 2013
    with 64-bit io functions
    
    Copyright (c) 1994 2013 Bernard van Duijnen All rights reserved.
    
     Strictly Oracle Internal Use Only
    
    
    DUL: Warning: Recreating file "dul.log"
    Reading USER.dat 91 entries loaded
    Reading OBJ.dat 74764 entries loaded and sorted 74764 entries
    Reading TAB.dat 2882 entries loaded
    Reading COL.dat 94598 entries loaded and sorted 94598 entries
    Reading SEG.dat 17 entries loaded
    Reading EXT.dat 43 entries loaded and sorted 43 entries
    Reading TABPART.dat 150 entries loaded and sorted 150 entries
    Reading TABCOMPART.dat 3 entries loaded and sorted 3 entries
    Reading TABSUBPART.dat 36 entries loaded and sorted 36 entries
    Reading INDPART.dat 169 entries loaded and sorted 169 entries
    Reading INDCOMPART.dat 0 entries loaded and sorted 0 entries
    Reading INDSUBPART.dat 0 entries loaded and sorted 0 entries
    Reading IND.dat 5150 entries loaded
    Reading LOB.dat
    DUL: Warning: Increased the size of DC_LOBS from 1024 to 8192 entries
     1286 entries loaded
    Reading ICOL.dat 7569 entries loaded
    Reading COLTYPE.dat 3003 entries loaded
    Reading TYPE.dat 2872 entries loaded
    Reading ATTRIBUTE.dat 11127 entries loaded
    Reading COLLECTION.dat 985 entries loaded
    Reading COMPATSEG.dat 0 entries loaded
    Reading BOOTSTRAP.dat 60 entries loaded
    Reading LOBFRAG.dat 1 entries loaded and sorted 1 entries
    Reading LOBCOMPPART.dat 0 entries loaded and sorted 0 entries
    Reading UNDO.dat 21 entries loaded
    Reading TS.dat 10 entries loaded
    Reading PROPS.dat 36 entries loaded
    Database character set is ZHS16GBK
    Database national character set is AL16UTF16
    Found db_id = 4188950066
    Found db_name = ORA11G
    

    unload 语法

    UNLOAD [TABLE]  [  schema_name . ]  table_name 
                  [ PARTITION(  partition_name ) ]
                  [ SUBPARTITION(  sub_partition_name ) ]
                  [ (  column_definitions ) ]
                  [  cluster_clause  ]
                  [  storage_clause  ] ;
    

    unload整个表

    DUL> unload table chf.SALES;
    . unloading table                     SALES
     . Unloading partition                      P1
     .   Unloading sub partition                 P1_SUB1
     .   Unloading sub partition                 P1_SUB2
     . Unloading partition                      P2
     .   Unloading sub partition                 P2_SUB1
     .   Unloading sub partition                 P2_SUB2
    .           table SALES total        5 rows unloaded
    
    [root@xifenfei dul]# ls -l CHF_SALES*
    -rw-r--r-- 1 oracle oinstall 421 Jan 19 18:09 CHF_SALES.ctl
    -rw-r--r-- 1 oracle oinstall 251 Jan 19 18:09 CHF_SALES.dat
    [root@xifenfei dul]# more CHF_SALES.dat
    |00001| |01-JAN-2002 AD 00:00:00| |100| |ACTIVE|
    |00002| |01-JAN-2001 AD 00:00:00| |200| |ACTIVE|
    |00005| |04-FEB-2002 AD 00:00:00| |300| |INACTIVE|
    |00003| |01-FEB-2003 AD 00:00:00| |300| |INACTIVE|
    |00004| |04-FEB-2003 AD 00:00:00| |300| |INACTIVE|
    

    unload 分区表

    DUL> unload table chf.SALES PARTITION(p1);
    . unloading table                     SALES
     . Unloading partition                      P1
     .   Unloading sub partition                 P1_SUB1
     .   Unloading sub partition                 P1_SUB2
    .           table SALES total        3 rows unloaded
    
    [root@xifenfei dul]# ls -l CHF_SALES_P1*
    -rw-r--r-- 1 oracle oinstall 424 Jan 19 18:10 CHF_SALES_P1.ctl
    -rw-r--r-- 1 oracle oinstall 149 Jan 19 18:10 CHF_SALES_P1.dat
    [root@xifenfei dul]# more CHF_SALES_P1.dat
    |00001| |01-JAN-2002 AD 00:00:00| |100| |ACTIVE|
    |00002| |01-JAN-2001 AD 00:00:00| |200| |ACTIVE|
    |00005| |04-FEB-2002 AD 00:00:00| |300| |INACTIVE|
    

    unload 子分区表

    DUL> unload table chf.SALES SUBPARTITION(p2_SUB2);
    . unloading table                     SALES
     . Unloading partition                      P1
     . Unloading partition                      P2
     .   Unloading sub partition                 P2_SUB2
    .           table SALES total        2 rows unloaded
    
    [root@xifenfei dul]# ls -l CHF_SALES_P2_SUB2*
    -rw-r--r-- 1 oracle oinstall 429 Jan 19 18:14 CHF_SALES_P2_SUB2.ctl
    -rw-r--r-- 1 oracle oinstall 102 Jan 19 18:14 CHF_SALES_P2_SUB2.dat
    [root@xifenfei dul]# more CHF_SALES_P2_SUB2.dat
    |00003| |01-FEB-2003 AD 00:00:00| |300| |INACTIVE|
    |00004| |04-FEB-2003 AD 00:00:00| |300| |INACTIVE|
    

    验证控制文件

    [root@xifenfei dul]# ls -l CHF_SALES*
    -rw-r--r-- 1 oracle oinstall 421 Jan 19 18:09 CHF_SALES.ctl
    -rw-r--r-- 1 oracle oinstall 251 Jan 19 18:09 CHF_SALES.dat
    -rw-r--r-- 1 oracle oinstall 424 Jan 19 18:10 CHF_SALES_P1.ctl
    -rw-r--r-- 1 oracle oinstall 149 Jan 19 18:10 CHF_SALES_P1.dat
    -rw-r--r-- 1 oracle oinstall 429 Jan 19 18:14 CHF_SALES_P2_SUB2.ctl
    -rw-r--r-- 1 oracle oinstall 102 Jan 19 18:14 CHF_SALES_P2_SUB2.dat
    [root@xifenfei dul]# more CHF_SALES.ctl
    load data
    CHARACTERSET ZHS16GBK
    infile 'CHF_SALES.dat'
    insert
    into table "CHF"."SALES"
    fields terminated by whitespace
    (
      "PRODUCT_ID"                       CHAR(5) enclosed by X'7C'       
     ,"SALES_DATE"                       DATE "DD-MON-YYYY AD HH24:MI:SS" enclosed by X'7C'
     ,"SALES_COST"                       CHAR(3) enclosed by X'7C'       
     ,"STATUS"                           CHAR(8) enclosed by X'7C'       
    )
    [root@xifenfei dul]# more CHF_SALES_P1.ctl
    load data
    CHARACTERSET ZHS16GBK
    infile 'CHF_SALES_P1.dat'
    insert
    into table "CHF"."SALES"
    fields terminated by whitespace
    (
      "PRODUCT_ID"                       CHAR(5) enclosed by X'7C'       
     ,"SALES_DATE"                       DATE "DD-MON-YYYY AD HH24:MI:SS" enclosed by X'7C'
     ,"SALES_COST"                       CHAR(3) enclosed by X'7C'       
     ,"STATUS"                           CHAR(8) enclosed by X'7C'       
    )
    [root@xifenfei dul]# more CHF_SALES_P2_SUB2.ctl
    load data
    CHARACTERSET ZHS16GBK
    infile 'CHF_SALES_P2_SUB2.dat'
    insert
    into table "CHF"."SALES"
    fields terminated by whitespace
    (
      "PRODUCT_ID"                       CHAR(5) enclosed by X'7C'       
     ,"SALES_DATE"                       DATE "DD-MON-YYYY AD HH24:MI:SS" enclosed by X'7C'
     ,"SALES_COST"                       CHAR(3) enclosed by X'7C'       
     ,"STATUS"                           CHAR(8) enclosed by X'7C'       
    )
    

    这里证明所有的控制文件中的表结构都是整个表的结构,而不是分区表,在实际处理过程中,可以考虑交换分区来实现
     

    -----------------温馨提示--------------------
    操作有风险,动手需谨慎
    Oracle研究中心
    http://www.oracleplus.net
    本文由大师惜分飞原创分享,转载请尽量保留本站网址

    --------------------------------------ORACLE-DBA----------------------------------------

    最权威、专业的Oracle案例资源汇总之学习笔记:Oracle dul数据挖掘 使用DUL数据恢复软件恢复分区表中

    原文唯一网址:http://www.oracleplus.net/arch/oracle-20160522-215.html

    Oracle研究中心

    关键词:

    Oracle dul数据挖掘

    使用DUL数据恢复软件恢复分区表中的数据

  • 相关阅读:
    B/S学习总结
    鶴山 李正浩 博士(探访墓所)
    毕业工作五年的总结和感悟(上)
    NSURLConnection经常使用的代理方法
    14.2 事务的ACID属性
    Search a 2D Matrix -- LeetCode
    ios开发之-继承的实现运用
    【Android】读取sdcard上的图片
    BZOJ 2820 YY的GCD 莫比乌斯反演
    linux写环境变量对字符转义
  • 原文地址:https://www.cnblogs.com/piguanjia/p/5608281.html
Copyright © 2020-2023  润新知