标签云
asm恢复 bbed bootstrap$ dul kcbzib_kcrsds_1 kccpb_sanity_check_2 kcratr_nab_less_than_odr MySQL恢复 ORA-00312 ORA-00704 ORA-00742 ORA-01110 ORA-01200 ORA-01555 ORA-01578 ORA-01595 ORA-600 2662 ORA-600 2663 ORA-600 3020 ORA-600 4000 ORA-600 4137 ORA-600 4193 ORA-600 4194 ORA-600 16703 ORA-600 kcbzib_kcrsds_1 ORA-600 KCLCHKBLK_4 ORA-600 kcratr_nab_less_than_odr ORA-600 kdsgrp1 ORA-15042 ORA-15196 ORACLE 12C oracle dul ORACLE PATCH Oracle Recovery Tools oracle加密恢复 oracle勒索 oracle勒索恢复 oracle异常恢复 ORACLE恢复 Oracle 恢复 ORACLE数据库恢复 oracle 比特币 OSD-04016 YOUR FILES ARE ENCRYPTED 比特币加密文章分类
- Others (2)
- 中间件 (2)
- WebLogic (2)
- 操作系统 (110)
- 数据库 (1,833)
- DB2 (22)
- MySQL (81)
- Oracle (1,662)
- Data Guard (53)
- EXADATA (8)
- GoldenGate (24)
- ORA-xxxxx (168)
- ORACLE 12C (72)
- ORACLE 18C (6)
- ORACLE 19C (15)
- ORACLE 21C (3)
- Oracle 23ai (8)
- Oracle ASM (69)
- Oracle Bug (8)
- Oracle RAC (54)
- Oracle 安全 (6)
- Oracle 开发 (28)
- Oracle 监听 (29)
- Oracle备份恢复 (628)
- Oracle安装升级 (103)
- Oracle性能优化 (62)
- 专题索引 (5)
- 勒索恢复 (88)
- PostgreSQL (37)
- pdu工具 (7)
- PostgreSQL恢复 (13)
- SQL Server (34)
- SQL Server恢复 (14)
- TimesTen (7)
- 达梦数据库 (3)
- 达梦恢复 (1)
- 生活娱乐 (2)
- 至理名言 (11)
- 虚拟化 (2)
- VMware (2)
- 软件开发 (47)
- Asp.Net (9)
- JavaScript (12)
- PHP (2)
- 小工具 (30)
-
最近发表
- .wman扩展名勒索mysql数据库恢复
- Oracle数据库被勒索加密一键open工具–OraFHR
- 通过alert日志回顾其他dba oracle异常恢复故障处理以及后续open数据库操作
- 年前几例Oracle数据库被加密为.wman的数据库故障恢复
- 文件系统损坏导致数据库异常故障处理
- expdp导出xml列报ORA-22924故障处理
- obet处理ORA-704 ORA-604 ORA-1578故障
- obet修复csc higher than block scn类型坏块
- ORA-600 kcratr_nab_less_than_odr和ORA-600 4193故障处理
- aix环境10g由于控制器异常导致ORA-600 4000故障处理
- ORA-600 3716故障处理
- 不当恢复truncate数据导致数据库不能open处理
- 注意:PostgreSQL库出现readme_to_recover勒索
- Oracle 19c 202601补丁(RUs+OJVM)-19.30
- Patch_SCN快速解决ORA-600 2663故障
- 在生产环境错误执行dd命令破坏asm磁盘故障恢复
- obet实现对数据文件坏块检测功能
- oracle linux 8.10注意pmlogger导致空间被大量占用
- obet快速修改scn/resetlogs恢复数据库(缺少归档,ORA-00308)
- 使用DBMS_PDB.RECOVER抢救单个pdb
标签归档:drop恢复
dul恢复drop表测试
dul对被drop对象进行恢复,需要提供两个信息
1.被删除表所属表空间(非必须)
2.被删除表结构(必须)
模拟删除表
--创建测试表
SQL> create table t_dul_drop tablespace czum
2 as
3 select * from dba_tables;
Table created.
--备份被删除表数据,便于比较和提供测试表结构
SQL> create table t_dul_drop_bak tablespace users
2 as select * from t_dul_drop;
Table created.
SQL> alter system switch logfile;
System altered.
SQL> select count(*) from t_dul_drop;
COUNT(*)
----------
1785
SQL> drop table chf.t_dul_drop purge;
Table dropped.
SQL> alter system checkpoint;
System altered.
使用logminer找到data_object_id
delete from "SYS"."OBJ$" where "OBJ#" = '68474' and "DATAOBJ#" = '68474'
and "OWNER#" = '61' and "NAME" = 'T_DUL_DROP' and "NAMESPACE" = '1' and
"SUBNAME" IS NULL and "TYPE#" = '2' and "CTIME" = TO_DATE('04-FEB-13', 'DD-MON-RR')
and "MTIME" = TO_DATE('04-FEB-13', 'DD-MON-RR') and "STIME" = TO_DATE('04-FEB-13', 'DD-MON-RR')
and "STATUS" = '1' and "REMOTEOWNER" IS NULL and "LINKNAME" IS NULL and "FLAGS" = '0'
and "OID$" IS NULL and "SPARE1" = '6' and "SPARE2" = '1' and "SPARE3" = '61' and
"SPARE4" IS NULL and "SPARE5" IS NULL and "SPARE6" IS NULL and ROWID = 'AAAAASAABAAAPzCAAV';
这里可以知道,被删除表的data_object_id为68474
DUL恢复被删除表
--dul版本
E:\dul10>dul.exe
Data UnLoader 10.2.4.37 - Oracle Internal Only - on Mon Feb 04 23:49:50 2013
with 64-bit io functions
Copyright (c) 1994 2010 Bernard van Duijnen All rights reserved.
Strictly Oracle Internal use Only
DUL> ALTER SESSION SET USE_SCANNED_EXTENT_MAP = TRUE;
Parameter altered
--扫描所属表空间
DUL> scan tablespace 6;
Scanning tablespace 6, data file 6 ...
13 segment header and 331 data blocks
tablespace 6, data file 6: 1279 blocks scanned
Reading EXT.dat 13 entries loaded and sorted 13 entries
Reading SEG.dat 13 entries loaded
Reading COMPATSEG.dat 0 entries loaded
Reading SCANNEDLOBPAGE.dat 0 entries loaded and sorted 0 entries
--scan tables得到需求表(可以核对数据样例)
DUL> scan tables;
UNLOAD TABLE OBJNO68474 ( COL001 VARCHAR2(11), COL002 VARCHAR2(30), COL003 VARCHAR2(6)
, COL004 VARCHAR2(20), COL005 VARCHAR2(30), COL006 VARCHAR2(5), COL007 NUMBER
, COL008 NUMBER, COL009 NUMBER, COL010 NUMBER, COL011 NUMBER
, COL012 NUMBER, COL013 NUMBER, COL014 NUMBER, COL015 CHAR
, COL016 NUMBER, COL017 NUMBER, COL018 VARCHAR2(3), COL019 VARCHAR2(1)
, COL020 NUMBER, COL021 NUMBER, COL022 NUMBER, COL023 NUMBER
, COL024 NUMBER, COL025 NUMBER, COL026 NUMBER, COL027 NUMBER
, COL028 VARCHAR2(10), COL029 VARCHAR2(10), COL030 VARCHAR2(5), COL031 VARCHAR2(7)
, COL032 NUMBER, COL033 DATE, COL034 VARCHAR2(3), COL035 VARCHAR2(12)
, COL036 VARCHAR2(1), COL037 VARCHAR2(1), COL038 VARCHAR2(3), COL039 VARCHAR2(7)
, COL040 VARCHAR2(7), COL041 VARCHAR2(7), COL042 VARCHAR2(8), COL043 VARCHAR2(3)
, COL044 VARCHAR2(2), COL045 VARCHAR2(15), COL046 VARCHAR2(8), COL047 VARCHAR2(3)
, COL048 VARCHAR2(3), COL049 VARCHAR2(8), COL050 VARCHAR2(8), COL051 VARCHAR2(5)
, COL052 VARCHAR2(2), COL053 VARCHAR2(2), COL054 VARCHAR2(3), COL055 VARCHAR2(7) )
STORAGE( DATAOBJNO 68474 );
--恢复删除表(业务提供表结构)
DUL> unload table t_dul_drop(
2 OWNER VARCHAR2(30),
3 TABLE_NAME VARCHAR2(30),
4 TABLESPACE_NAME VARCHAR2(30),
5 CLUSTER_NAME VARCHAR2(30),
6 IOT_NAME VARCHAR2(30),
7 STATUS VARCHAR2(8) ,
8 PCT_FREE NUMBER ,
9 PCT_USED NUMBER ,
10 INI_TRANS NUMBER ,
11 MAX_TRANS NUMBER ,
12 INITIAL_EXTENT NUMBER ,
13 NEXT_EXTENT NUMBER ,
14 MIN_EXTENTS NUMBER ,
15 MAX_EXTENTS NUMBER ,
16 PCT_INCREASE NUMBER ,
17 FREELISTS NUMBER ,
18 FREELIST_GROUPS NUMBER ,
19 LOGGING VARCHAR2(3) ,
20 BACKED_UP VARCHAR2(1) ,
21 NUM_ROWS NUMBER ,
22 BLOCKS NUMBER ,
23 EMPTY_BLOCKS NUMBER ,
24 AVG_SPACE NUMBER ,
25 CHAIN_CNT NUMBER ,
26 AVG_ROW_LEN NUMBER ,
27 AVG_SPACE_FREELIST_BLOCKS NUMBER ,
28 NUM_FREELIST_BLOCKS NUMBER ,
29 DEGREE VARCHAR2(20),
30 INSTANCES VARCHAR2(20),
31 CACHE VARCHAR2(10),
32 TABLE_LOCK VARCHAR2(8) ,
33 SAMPLE_SIZE NUMBER ,
34 LAST_ANALYZED DATE ,
35 PARTITIONED VARCHAR2(3) ,
36 IOT_TYPE VARCHAR2(12),
37 TEMPORARY VARCHAR2(1) ,
38 SECONDARY VARCHAR2(1) ,
39 NESTED VARCHAR2(3) ,
40 BUFFER_POOL VARCHAR2(7) ,
41 FLASH_CACHE VARCHAR2(7) ,
42 CELL_FLASH_CACHE VARCHAR2(7) ,
43 ROW_MOVEMENT VARCHAR2(8) ,
44 GLOBAL_STATS VARCHAR2(3) ,
45 USER_STATS VARCHAR2(3) ,
46 DURATION VARCHAR2(15),
47 SKIP_CORRUPT VARCHAR2(8) ,
48 MONITORING VARCHAR2(3) ,
49 CLUSTER_OWNER VARCHAR2(30),
50 DEPENDENCIES VARCHAR2(8) ,
51 COMPRESSION VARCHAR2(8) ,
52 COMPRESS_FOR VARCHAR2(12),
53 DROPPED VARCHAR2(3) ,
54 READ_ONLY VARCHAR2(3) ,
55 SEGMENT_CREATED VARCHAR2(3) ,
56 RESULT_CACHE VARCHAR2(7))
57 STORAGE( DATAOBJNO 68474 );
. unloading table T_DUL_DROP
DUL: Warning: Recreating file "T_DUL_DROP.ctl"
1785 rows unloaded
模拟业务规则提供,创建表
SQL> create table t_dul_drop as select * from t_dul_drop_bak where 1=0; Table created.
导入数据
e:\dul10>sqlldr chf/xifenfei control=T_DUL_DROP.ctl SQL*Loader: Release 11.2.0.3.0 - Production on Mon Feb 4 23:35:57 2013 Copyright (c) 1982, 2011, Oracle and/or its affiliates. All rights reserved. Commit point reached - logical record count 64 Commit point reached - logical record count 128 Commit point reached - logical record count 192 Commit point reached - logical record count 256 Commit point reached - logical record count 320 Commit point reached - logical record count 384 Commit point reached - logical record count 448 Commit point reached - logical record count 512 Commit point reached - logical record count 576 Commit point reached - logical record count 640 Commit point reached - logical record count 704 Commit point reached - logical record count 768 Commit point reached - logical record count 832 Commit point reached - logical record count 896 Commit point reached - logical record count 960 Commit point reached - logical record count 1024 Commit point reached - logical record count 1088 Commit point reached - logical record count 1152 Commit point reached - logical record count 1216 Commit point reached - logical record count 1280 Commit point reached - logical record count 1344 Commit point reached - logical record count 1408 Commit point reached - logical record count 1472 Commit point reached - logical record count 1536 Commit point reached - logical record count 1600 Commit point reached - logical record count 1664 Commit point reached - logical record count 1728 Commit point reached - logical record count 1785
恢复数据结果
SQL> select count(*) from t_dul_drop;
COUNT(*)
----------
1785
SQL> select owner,table_name from t_dul_drop where rownum<10;
OWNER TABLE_NAME
------------------------------ ------------------------------
SYS IDL_CHAR$
SYS IDL_UB2$
SYS IDL_SB4$
SYS ERROR$
SYS SETTINGS$
SYS NCOMP_DLL$
SYS PROCEDUREJAVA$
SYS PROCEDUREC$
SYS PROCEDUREPLSQL$
9 rows selected.

加我微信(17813235971)
加我QQ(107644445)

