Oracle DUL Salvaging Oracle Data with Data UnLoader

Oracle DUL Salvaging Oracle Data with Data UnLoader

If you cannot recover the data by yourself, ask Parnassusdata, the professional ORACLE database recovery team for help.

Parnassusdata Software Database Recovery Team

Service Hotline:  +86 13764045638 E-mail: [email protected]

ORACLE PRM-DUL Download: http://zcdn.parnassusdata.com/DUL5108.zip

 

DULRULER

 

 

Salvaging Data with Data UnLoader

Full Agenda
Chapter 1: Overview
Chapter 2: Basics
Chapter 3: Parameters and Commands 
Chapter 4: Simple Data Salvage Scenarios
Chapter 5: Complex Data Salvage Scenarios
Chapter 6: Loading Data
Chapter 7: Internal Files
Chapter 8: Labs


Chapter 1: Overview
•	Prereqs: 
•	General knowledge of Oracle Database Architecture
•	High level file structures
•	Instance processes
•	General knowledge of Oracle Database Operations
•	Database states: started, mounted, open, shutdown 
•	export/import utilities
•	SQL*Loader
Overview Agenda
•	Concepts
•	When to use Data UnLoader?
•	“Normal” Data Recovery
•	Features
•	Limitations
•	Key Scoping Questions
•	Expectations
Overview: 
Concepts: What is Data UnLoader?
•	A C program developed by Bernard van Duijnen
•	Extracts only DATA for tables and clusters directly from database files (*.dbf)
•	Creates standard Export Dump files (*.dmp) or the combination SQL*Loader control/data files (.ctl/.dat) for loading data into a new or functioning database 
•	A stand-alone utility that has no dependence on the database instance being mounted or open

	DUL is strictly for Support and internal use only. 
 
Overview: 
Concepts: How it’s done
•	Unformats data by directly scanning datafiles (.dbf)
•	Data/segment/extent information and metadata is extracted from SYSTEM.dbf file if available
•	Data/segment/extent information is extracted using heuristics and user knowledge if SYSTEM.dbf file is NOT available
•	Does dirty reads (only data written to disk is extracted; data in memory is lost; archive logs are not used) 
•	Later enhancements have been made to extract data from standard export (.exp) or data pump files (.edp) as an alternative (although still a work in progress)

Overview: 
Concepts: Security
•	Data Security
•	Because DUL directly reads .dbf files
•	The database can be completely down
•	There is no database userid to audit access
•	Extracted data is easily viewable

•	Program Security
•	The availability and distribution of the DUL executable must be tightly limited and controlled


Overview: 
Concepts: History
•	Originally
•	An engineer was engaged on-site only 
•	The engineer was responsible for installing and removing the DUL executable from the client machine

•	Now
•	Remote is the preferred, faster method of delivery
•	Some low level, time-based “copy” protection has been implemented to expire DUL after 45 days

	Note: Most government contracts will not allow remote access and on-site is the only option.

Overview: 
Concepts: “Remote” Access Options
•	Customer could give direct access to host (VPN/putty)
•	This usually involves customer’s Security department and is either denied or takes too long for all approvals
•	Conduct a Webex or Beehive shared session to view and control activity with the DBA
•	The DUL.exe needs to be e-mailed/ftp’d to the DBA
•	Talk the DBA through the process on the phone
•	The DUL.exe needs to be e-mailed/ftp’d to the DBA
•	Pre-configure control files, e-mail to DBA, receive logs
•	ASE should be fairly knowledgeable of DUL
Overview: 
When to use Data UnLoader?
•	Generally, a decision is made by Global Product Support (GPS) from a Service Request
•	Only after all documented and undocumented data recovery methods have been evaluated and rejected
•	When “normal” methods of data/database recovery are not applicable or not practicable

	Note: While the most dramatic use of this process is for a downed database, it may also be used when the database is up and just partial data is missing or corrupt.
Overview: 
When to use Data UnLoader?
•	Examples
•	Customer has no usable backup
•	Inadequate backups/archives result in data loss
•	Internal errors or corruption are preventing the database from opening
•	MTTR is not acceptable using normal recovery methods (i.e. too many archive logs to apply)
•	Loss of SYSTEM datafile
•	A corrupt datafile has taken a tablespace offline

Overview:
When to use Data UnLoader?
•	DUL is intended to retrieve data that cannot be retrieved by other means
•	It is not an alternative to Database Recovery
•	It is a last resort, not for normal production usage
•	Note: There can be logical inconsistencies with the data retrieved.
	There is no guarantee of success!
•	This is primarily because of the unpredictable nature of corruptions and not all features or data types of the database have been implemented.
Overview:
“Normal” Database Recovery
•	Current database recovery options (manual) 
•	restore last backup and roll forward with archive logs
•	import from last full backup export
•	use SQL*Loader to re-load the data from source
•	use parallel create table as select (PCTS)
•	use transportable tablespaces
•	build a cloned database, export data, then import
•	RMAN (more automated)
•	Initiate an RMAN session with appropriate directives
Overview: 
“Normal” Database Recovery
•	Undocumented init.ora database parameters
•	_corrupted_rollback_segments
•	_allow_resetlogs_corruption  
•	Diagnostic/Editing tools
•	opatch (very old tool, see Notes 28864.1, 33182.1)
•	Block Browser/Editor (BBED) 
•	Note: BBED is no longer distributed starting with 11g

Overview:
“Normal” DB Recovery: Limitations
•	No alternatives in the case of loss of SYSTEM tablespace or datafile(s) 
•	The database must be in reasonably good condition or recovery is not possible even with the undocumented parameters 
•	Editing datafiles is cumbersome, dangerous, and not guaranteed to work
•	Extensive internal structure knowledge required
•	Certain corruptions are beyond editing
Overview: 
Supported Features
•	Works against Oracle v6 through v11  (12?)
•	Available for multiple (but not all) platforms
•	Linux, AIX, Solaris, Windows
•	DUL for HP-UX has been unavailable since 8/13/12
•	Cross platform extracts are possible

•	NOT an alternative to standard methods of recovery
•	NOT an officially supported utility
•	Use only as a last resort!
Overview: 
Supported Features
•	Reads data dictionary if SYSTEM datafile is available
•	However, it can extract data without SYSTEM datafile
•	Without SYSTEM, user/object/column names are lost
•	Can unload individual tables, tables by schema (users), tables by object number, or the entire database
•	Can unload extents from incomplete tables
•	Can unload cross platforms
•	i.e. Unload in Windows, Load in UNIX
•	Supports standard Oracle database constructs 
Overview: 
Supported Features: Constructs
•	chained rows, migrated rows 
•	hash/index clusters
•	longs, raws, blobs
•	rowids, dates, numbers
•	multiple free list groups
•	segment high water mark
•	unlimited extents
•	partitioned tables
Overview: 
Supported “New” Features
•	Configurable for Automatic Storage Management (ASM)
•	Easier configuration (tablespace and relative file numbers are now read directly from .dbf files)
•	Unexp (extract from an export file)
•	Unpump (extract from a data pump file)
•	SQL*Loader can now be used for long raws and blobs
•	Note:  The current version of DUL is 10.2.0.5.31
•	Base Release from 6/9/2011


Overview: 
Limitations / Restrictions
•	Database can be corrupt, but individual blocks must be good.  An error will go to the log for each bad block.
•	DUL unloads only table and cluster data
•	No support for MLSLABELS
•	No support for multibyte character sets
•	No support for some 11g features (i.e. encryption)
•	DUL v10 can be used against v11 datafiles

Overview: 
Limitations on 11g features (11/2012)
•	11g secure file lobs are in beta testing
•	Label security is not supported yet
•	Encryption is not supported yet
•	ASM disks on exadata cells are not supported yet
•	11g ASM with variable extent sizes and ASM striping support is  just recently available  
•	Complex types not supported in export_mode 
•	The generated dump file in export_mode=true does not contain metadata

Overview:
Key Scoping Questions
•	Before proceeding with an engagement, find out:
•	What platform? OS version? DB version? Blocksize?
•	Is the DB up or down? Can be it mounted? Opened? 
•	Is the SYSTEM.dbf datafile available? Readable?
•	Is remote access possible?  Is on-site required? 
•	How large is the DB or table(s) to be extracted?
•	Which data format is preferred? Export? SQL*Loader?
•	Is there enough available disk space for output?
•	Remind the customer that there is no guarantee of success.
Overview: 
Expectations
•	From ASE
•	Assess the customer environment and conditions 
•	Determine what data is needed or requested
•	Configure DUL for extracting data
•	“Best effort” to run DUL to deliver export dump files or SQL Loader files with data to the customer
•	Assist customer with 
•	Interpreting the DUL log
•	Planning for loading and verifying the data

Overview: 
Expectations
•	From Customer
•	Access to all required .dbf files (telnet, owc, ftp?)
•	Create new database (required if current db won’t open)
•	Load and verify data
•	If SYSTEM.dbf was missing, rename application objects and columns with assistance from application developers or functional staff members
•	Rebuild all required missing objects (indexes, triggers..)
•	Verify application functionality

Overview: 
Expectations
•	General questions from customer
•	How long will a DUL engagement take?
•	The setup time depends on 
•	what .dbf files are available, where and when
•	what kind of corruption that is encountered 
•	The extract time is dependent on the size of the database
•	The time to interpret results depends on
•	availability of SYSTEM.dbf
•	The time to reload new database
•	 the customer may not need ASE at this point after a few loads are completed
Overview:
The Future of DUL
•	Bernard continues to enhance DUL, however it is more difficult to support new features of 11g and 12c like encryption and compression.
	As more customers embrace unsupported new features, DUL will have more limited application.
•	Newer versions of the Oracle Database have additional data protection/recovery features (i.e. recycle bin, flash recovery/flashback options)
	As more customers embrace newer recovery features, there should be less calls for DUL.
Overview:
The Future of DUL
•	There will always be hardware/software failures and human error which cause databases to crash and lead to data loss.
•	There will always be customers using older versions of the database.
•	DUL will continue to be a valuable tool for salvaging data, although with limitations.

Quiz
1) After configuring and running DUL, an unknown error appears in the dul.log.  Which of the following should be done to get help quickly?
•	Open a SEV-1 SR with GPS immediately
•	Send an e-mail to [email protected] or call his cell phone
•	Send an e-mail to [email protected]
Quiz
2) The DUL program should not be executed while the database is mounted. 
•	True
•	False
Quiz
3) What is the output from a DUL run?
•	Export .dmp files
•	SQL*Loader .dat files
•	SQL*Loader .ctl files
•	A dul.log
•	All of the above
•	No output, DUL will restore data in place
Quiz
4) As long as the customer has a good SYSTEM.dbf datafile, DUL will extract all the required customer data and format an export dump file or SQL*Loader .dat data file.
•	True 
•	False
Quiz
5) As long as the customer has a good SYSTEM.dbf datafile, the only additional work for the customer will be to import the export files or run SQL*Loader.
•	True
•	False 
Quiz
6) When the customer is missing the SYSTEM.dbf datafile, DUL can still extract usable data. The ASE will rename table and column names to their appropriate application usable identities.
•	True
•	False

Chapter 2: Basics
•	Prereqs: 
•	Intermediate knowledge of Oracle Database Server
•	Use of imp utility, interactive and batch modes
•	Use of SQL*Loader 
•	General knowledge of UNIX/Windows command level
•	vi or other text editor on UNIX
•	WordPad on Windows
•	From https://stbeehive.oracle.com/teamcollab/overview/DUL
•	Download DataUnLoader_Toolkit.zip
•	Download DataUnLoader_Labs.zip
Basics: Agenda
•	Data UnLoader Architecture
•	What is needed?
•	Configuring DUL
•	Installing and Running DUL
•	Reviewing the output log

Basics:
Data UnLoader Architecture
•	INPUT
•	.dbf datafiles (can be offline copy, at alternate location)
•	2 .dul “control” files (not the DB control files)
•	User commands at DUL> prompt

•	dul.exe or dul (single file is about 500k)

•	OUTPUT
•	.dmp files (for importing later) or
•	.ctl and .dat files (for SQL*Loader)
•	Naming will be schema_tablename.filetype
•	log file (dul.log)

Basics:
What is needed?
•	Missing data? Got .dbf? Need dul.exe? Go to 
•	https://stbeehive.oracle.com/teamcollab/overview/DUL
•	Download executable for your desired platform
•	Best Practice: If going on-site, download all platforms ahead of time in case internal Oracle access is later prohibited.

•	Create and Configure an init.dul
•	OS and DB dependent parameters, directives

•	Create and Configure a control.dul 
•	Map datafiles to location on disk 
•	ASM is now supported (new feature)

Basics:
Go to the New DUL Website
Basics:
Download executable
Basics:
Configuring an init.dul
•	Contains parameters to help DUL understand the format and platform of the datafiles (.dbf) and what output format to use
•	This plain text file has information specifying  
•	DUL cache size
•	Details of header layout
•	Oracle block size
•	Output file format
•	Sql*Loader format and record size. 
•	Other optional directives
Basics:
Configuring an init.dul
•	Configuring the DUL cache sizes
•	These must be large enough to hold all entries from the DBA_TAB_COLUMNS, _TABLES, _OBJECTS, and _USERS tables
•	DC_COLUMNS =
•	DC_TABLES =
•	DC_OBJECTS = 
•	DC_USERS =
•	Note: DUL now uses these as minimum values and can dynamically increase as needed when run.
Basics:
Configuring an init.dul
•	Configuring the platform dependent parameters 
•	OSD_BIG_ENDIAN_FLAG = true/false
-	“Endianness” deals with the ordering of bits within a structure
-	On a big-endian platform, the 4 bytes of a word are allocated in the reverse order, high to low
-	Little endian ordering means storing the least significant byte at the least significant address 
-	Note: For DB >= 10g, this is the only osd parm needed


Basics:
Configuring an init.dul
•	OSD_DBA_FILE_BITS =
-	The number of bits in a data base address (dba) used for the low order part of file number.
•	OSD_C_STRUCT_ALIGNMENT =
-	Structure layout in data file headers.
•	OSD_FILE_LEADER_SIZE =
-	Number of blocks/bytes before the Oracle file header. Unix datafiles have an extra leading block (file size, block size magic number)


Basics:
Configuring an init.dul
•	Database specific parameters
•	db_block_size = 8192 /* db default block size */
•	compatible = 9            /* db version */
•	Sql*Loader or Export format parameters
•	export mode = false   /* for sql*loader, true=exp */
•	ldr_enclose_char = "  /* delimiter for sql*loader */
•	ldr_phys_rec_size = 81  /* output length */

•	Note: Additional parameters and values will be detailed in Chapter 3.

Basics:
Configuring an init.dul (sample)
dc_columns = 200000
dc_tables = 40000
dc_objects = 40000
dc_users = 2048

osd_big_endian_flag = true  # Only osd parm needed on >=10g
osd_dba_file_bits = 10
osd_c_struct_alignment = 32
osd_file_leader_size = 1
osd_word_size = 32

db_block_size = 8192
compatible=9

export_mode=false
ldr_enclose_char = "
ldr_phys_rec_size = 81

Basics:
Minimal init.dul
Latest Update from Bernard (7/7/14)
	DUL will now try to figure out all configuration parameters from the dbf headers
	Init.dul only needs:
	COMPATIBLE=n
	OSD_BIG_ENDIAN_FLAG=true/false 
–	For cross platform only
	When specified, DUL will use the parameter values that you post in init.dul
	A GENERIC_init.dul is included in DUL ToolKit
Basics:
Configuring a control.dul
•	Specifies where the data to be extracted is currently located
•	Datafile locations can be obtained at the OS level
•	If the database can mount, use SQL on v$datafile

•	Now supports 3 formats for line entries
•	file_piece_spec (traditional)
•	asm_disk_spec 
•	block_index_spec
Basics:
control.dul: file_piece_spec
•	[[tablespace_no] relative_file_number] data_file_name
		[ extra_leader_offset ]         
		[ startblock block_no ]         
		[ endblock block_no ]
		[ block_size nk ]

Note:  New with version >= 10, the tablespace_no and relative_file_number are optional!  They can now be read directly from the .dbf file header (if not corrupt). 
Basics:
Creating control.dul: file_piece_spec
If the datafile headers are corrupt or for some other reason not accessible to dul, you may be able to run the SQL below if the database is mountable or from a stand-by database. 

sqlplus /nolog 
connect / as sysdba 
startup mount
 
set trimspool on pagesize 0 linesize 256 feedback off 
column name format a200 
spool control.dul 

select ts#, rfile#, name from v$datafile; 
exit 
Basics:
Creating control.dul: file_piece_spec
•	The previous SQL assumes the database is mounted
•	However, it is also possible to generate the control.dul from a database control file 
•	 >strings   >control.dul

•	You can get the ts# and rfile# number by doing a dump from another database (if version < 10)  alter system dump datafile ‘c:\app\jdydek\oradata\orcl\users01.dbf’ block min 1 block max 2;  Look for the fields below in the trace file: File Number=4 RelFno: 4 Basics: Sample Output: alter system dump datafile Start dump data block from file D:\MY_DATA\DULCLASS\USERS.DBF minblk 1 maxblk 2 V10 STYLE FILE HEADER: Compatibility Vsn = 169869568=0xa200100 Db ID=2596130611=0x9abdcf33, Db Name='XE' Activation ID=0=0x0 Control Seq=323=0x143, File size=12800=0x3200 File Number=4, Blksiz=8192, File Type=3 DATA … File Space Header Block: Header Control: RelFno: 4, Unit: 8, Size: 12800, Flag: 9 AutoExtend: YES, Increment: 1280, MaxSize: 655360 Initial Area: 7, Tail: 12800, First: 42, Free: 1557 Deallocation scn: 0.0 Header Opcode: Save: No Pending Op End dump data block from file D:\MY_DATA\DULCLASS\USERS.DBF minblk 2 maxblk 2 Basics: control.dul: with optional ts# and file# 0 1 /p012/oracle/GTU5ASP/system.dbf 1 2 /p014/oracle/GTU5ASP/undotbs01.dbf 2 3 /p015/oracle/GTU5ASP/sysaux01.dbf 4 4 /p028/oracle/GTU5ASP/pinn_data01.dbf 0 5 /p030/oracle/GTU5ASP/system02.dbf 4 6 /p020/oracle/GTU5ASP/pinn_data02.dbf 1 7 /p018/oracle/GTU5ASP/undotbs02.dbf 4 8 /p033/oracle/GTU5ASP/pinn_data03.dbf Above can be obtained by running the following SQL on the database in ‘mount’ mode.  select ts#, rfile#, name from v$datafile; Note: Even without ts# and rfile#, this is useful to capture all datafile names Basics: control.dul: without optional parms /p012/oracle/GTU5ASP/system.dbf /p014/oracle/GTU5ASP/undotbs01.dbf /p015/oracle/GTU5ASP/sysaux01.dbf /p028/oracle/GTU5ASP/pinn_data01.dbf /p030/oracle/GTU5ASP/system02.dbf /p020/oracle/GTU5ASP/pinn_data02.dbf /p018/oracle/GTU5ASP/undotbs02.dbf /p033/oracle/GTU5ASP/pinn_data03.dbf Note: dul v10 can now read tablespace number and relative file number directly from dbf headers if not corrupt. Basics: control.dul: asm_disk_spec • DISK device name [ disk group options ] • disk group option ::= GROUP disk group name | DISK_NO disk number in group | F1B1 File1 Block1 location • Note: Device name is generally sufficient. Other properties are retrieved from the file headers Basics: Sample control.dul: asm_disk_spec # ASM disks for disk groups disk /media/maxtor/asm/dgn1 disk /media/maxtor/asm/dgn2 disk /media/maxtor/asm/dgn3 disk /media/maxtor/asm/dgodd # system datafile in the first asm disk group +DGN/db102/datafile/system.257.621616979 # users datafile in a different disk group +DGODD/db102/datafile/users.257.621616683 • 11/27/12: The latest DUL executables have a new layer of asm support for fine grained striping and variable extent sizes. Basics: control.dul: block_index_spec • BLOCK INDEX block_index_name • A block index is a way to access Oracle blocks on corrupt file systems • Before using in control.dul, use the DUL command: • CREATE BLOCK INDEX index_name ON device ; • Useful to merge multiple disk images or to unload from corrupted file systems. This is only useful in extreme file system corruption scenarios. Basics: Installing and Running DUL • dul.exe is command and parameter driven, using a structure similar to SQL*Plus (about 18 commands) • See Chapter 3 and the online manual for command details • There is no “installer” program. Just copy the .exe program to a desired directory. Create init.dul and control.dul with text editor. • Run DUL from a UNIX shell or Windows DOS prompt. • >./dul.exe       /* for UNIX */
•	>dul               /* for Windows */

•	Best Practice:  DUL output goes to the same directory where the executable is located.  Create a separate directory for dul.exe and output while letting the control.dul direct the input.

Basics:
Running DUL: Common Commands
•	Some common, standard commands (interactive or batched)
•	SHOW PARAMETERS;	/* display all parm settings */
•	BOOTSTRAP;		/* read dictionary metadata */
•	SCAN DATABASE;	/* scans all known datafiles */
•	SCAN TABLES; or SCAN EXTENTS;
•	UNLOAD DATABASE;	/* extracts all users/tables */
•	UNLOAD TABLE schema.table (…..) ;
•	UNLOAD USER user_name;
•	UNLOAD OBJECT number;
•	EXIT; or BYE;		/* end dul session */

•	Chapter 3 will review details of all commands
Basics:
“New” commands / features
•	Updated user guide online (getting better all the time)
•	ASM support (control.dul format is different)
•	SCAN LOB SEGMENT FOR …
•	UNEXP TABLE schema.table_name
•	UNPUMP …  (wip, check with Bernard)
•	dul.exe has some built-in “copy” protection
•	Always download the current version
•	Date sensitive inactivation may stop the program from  executing
	Cannot start now
	You need a more recent DUL version for this os

Basics:
Reviewing the dul.log
•	Each successive execution of dul.exe will create a log
•	By default, the log is named “dul.log” 
•	When doing multiple runs of DUL, 
•	By default, each run will overwrite the dul.log
•	Set RESET_LOGFILE=false to append dul.logs for each run or rename dul.log between each run

•	Note:  Although you may set only about 10 parameters in the init.dul, there are actually about 50 possible parameters.  Those not set will have default values.  The log will show all parameters’ values for that specific run.
Basics:
Sample dul.log
DUL version 10.2.0.5.17 with 64-bits i/o

Init.dul parameter settings:
_SLPE_DEBUG = FALSE
ALLOW_CHECKSUM_MISMATCH = FALSE
ALLOW_DBA_MISMATCH = FALSE
ALLOW_OTHER_OBJNO = FALSE
ALLOW_TRAILER_MISMATCH = FALSE
ASM_DO_HARD_CHECKS = TRUE
AUTO_UPDATE_CHECKSUM = TRUE
AUTO_UPDATE_TRAILER = TRUE
BUFFER = 1048576
CF_FILES = 1022
CF_TABLESPACES = 64
COMPATIBLE = 10
CONTROL_FILE = control.dul
DB_BLOCK_SIZE = 8192
DB_NAME = 

Basics:
Sample dul.log
…

UNEXP_VERBOSE = FALSE
USE_LOB_FILES = FALSE
USE_SCANNED_EXTENT_MAP = false
VERIFY_NUMBER_PRECISION = TRUE
WARN_RECREATE_FILES = TRUE
WRITABLE_DATAFILES = FALSE

Reading USER.dat 42 entries loaded
Reading OBJ.dat 16246 entries loaded and sorted 16246 entries
Reading TAB.dat 1512 entries loaded
Reading COL.dat 58768 entries loaded and sorted 58768 entries
Reading TABPART.dat
DUL: Error: File TABPART.dat, line 1: token missing
DUL: Warning: Ignoring file TABPART.dat cache

Basics:
Sample dul.log
Database national character set is AL16UTF16
Entries from control file control.dul:

DUL: Error: open( 'C:\ORACLEXE\ORADATA\XE\SYSTEM.DBF', Read Only)
OS error 2: No such file or directory

DUL: Error: open( 'C:\ORACLEXE\ORADATA\XE\DULDAT01.DBF', Read Only)
OS error 2: No such file or directory

DUL: Error: open( 'D:\DULDAT02-corrupt.DBF', Read Only)
OS error 2: No such file or directory

DUL> show parameters
…
DUL> bye
Goodbye


Basics:
Simple vs. Complex Data Extracts 
•	Simple: With the SYSTEM datafile
•	Schema names, table names, column names and attributes are accessible
•	BOOTSTRAP; reads info from the data dictionary

•	Complex: Without the SYSTEM tablespace
•	Schema names, table names, attribute names must be mapped by the customer
•	SCAN DATABASE; SCAN TABLES; 
	or SCAN EXTENTS;
•	Set use_scanned_extents_map=true to UNLOAD

Basics
Other Complex Data Extracts 
•	Complex:  With or without SYSTEM.dbf
•	Extract data from a truncated a table
•	Extract data from a dropped a table
•	Extract data from a deleted a table
•	Extract original data from a truncated table that was partially inserted into.

•	Note: Beginning with 10g, new database features (i.e. recycle bin, flashback) can avoid many of the above scenarios, but only if they are properly configured.
Basics:
Preparing to engage
•	DUL Preflight Questions list
•	Get preflight answers via e-mail or scoping call
•	Set customer expectations
•	Download current exe zip/gz file for platform
•	DUL Utility (Note: date effective copy protection)
•	DUL Manual
•	If going on-site, copy to a CD or USB drive
•	Note that all platforms can fit on a single CD
•	Cross platform DUL is possible
•	If not going on-site, e-mail or ftp to customer

Quiz
1) If misconfigured and DUL produces an error message, what steps are necessary to rerun?
•	Modify the parameters and restart
•	Reinstall DUL and move .dbf files to new directory
•	Backup the log and datafiles
•	DUL cannot be rerun
Quiz	
2) Explain the function of these files:
•	init.dul
•	control.dul
•	dul.exe
•	dul.log
•	system.dbf
Quiz
3) Explain the differences in the state of the data dictionary after each of the following and which technique would be used to extract data:
a) the database won’t open
b) the database won’t mount
c) a table is truncated
d) table rows are deleted
e) a table is dropped


Chapter 3: 
Parameters and Commands
•	Prereqs: 
•	Intermediate knowledge of Oracle Database Server
•	Use of imp utility, interactive and batch modes
•	Use of SQL*Loader 
•	General knowledge of UNIX/Windows command level
•	vi or other text editor on UNIX
•	WordPad on Windows
Parameters and Commands 
Agenda
•	Startup sequence

•	Most Useful Parameters 
•	Rarely Used Parameters
•	Undocumented Parameters

•	Most Useful Commands
•	Rarely Used Commands

Parameters and Commands
Startup Sequence
>dul [optional command filename]
•	The parameter file (default "init.dul“) is processed. 
•	The control file (default "control.dul") is processed.
•	Tries to load dumps of the USER$, OBJ$, TAB$ and COL$ if available into DUL's data dictionary cache. 
•	Tries to load seg.dat and col.dat. 
•	Display “DUL>” prompt and accept commands (or run the commands in the filename specified as a first argument in the command line) 

Parameters and Commands 
Most Useful Parameters
•	CONTROL_FILE = control.dul
•	File name where .dbf location input comes from
•	“control.dul” is the default

•	LOGFILE = dul.log
•	File name where the run output is written
•	“dul.log” is the default

•	RESET_LOGFILE = [TRUE/false]
•	If true, each run of DUL overrides previous dul.log




Parameters and Commands 
Most Useful Parameters
•	DB_NAME=text
•	DB_ID=number
•	These optional parameters can be used to tell DUL exactly which database instance (by name or id) to process.
•	Useful if customer unintentionally supplies .dbf files from multiple databases.
•	DUL will report mismatched .dbf files in the dul.log
•	It would be best to remove these .dbf files from the control.dul and rerun the dul session. 
Parameters and Commands 
Most Useful Parameters
•	EXPORT_MODE=[true/false]
•	If true, DUL outputs export (.dmp) files
•	If false, DUL outputs SQL*Loader files (.dat and .ctl)

•	When using SQL*Loader output
•	LDR_ENCLOSE_CHAR = "   /* delimiter  char */
•	LDR_OUTPUT_IN_UTF8 =[true/false]
•	LDR_PHYS_REC_SIZE = 81
•	If 0, no fixed size; each line ends with new line character
•	If >2, each line is a fixed size
Parameters and Commands 
Most Useful Parameters
•	BUFFER=1048576
•	Specifies a number of bytes for buffering a row
•	The row output buffer size is used in both export and SQL*Loader modes
•	Each row is first stored in this buffer
•	Only complete rows without errors are written to the output file
•	DUL will fail if this is exceeded and must be restarted
•	In most cases, the default 1M is sufficient.  However don’t panic if dul fails with a buffer too small error


Parameters and Commands 
Most Useful Parameters
•	FILE_SIZE_IN_MB=number
•	A number specifying the maximum dump (.dmp) file size in megabytes. The default 0 means unlimited.
•	This is useful when the customer has limited disk space
•	Dump files larger than this are split into multiple pieces as DUL is running
•	This gives the customer a chance to copy files to another file system and reclaim space by deleting
•	Each partial dump file can be imported independently
Parameters and Commands 
Most Useful Parameters
•	COMPATIBLE=[6,7,8,9,10,11]
•	Specify the database version 
•	DB_BLOCK_SIZE=8192
•	Specify the default database block size
•	USE_SCANNED_EXTENT_MAP = [FALSE/true]
•	When false (default), use extent map from seg header
•	When true, use extent map from external ext.dat file created from SCAN command to unload tables
•	The ext.dat may be generated separately in a different run when more complex conditions require it


Parameters and Commands 
Rarely Used Parameters
•	ALLOW_CHECKSUM_MISMATCH = FALSE
•	If true, skips checks for block checksum
•	ALLOW_DBA_MISMATCH = FALSE
•	If true, skips check for block address
•	ALLOW_OTHER_OBJNO = FALSE
•	If true, skips check for valid object numbers
•	ALLOW_TRAILER_MISMATCH = FALSE
•	If true, skips check for block trailer
•	Be careful before setting any of these to TRUE!



Parameters and Commands 
Rarely Used Parameters
•	FILE = text
•	text is used as a base to generate 8.3 DOS filenames
•	MAX_OPEN_FILES = 8
•	The maximum #dbfs left open concurrently at OS level
•	PARSE_HEX_ESCAPES = FALSE
•	\\xhh hex escape sequences used while parsing? No 
•	If set to TRUE, then \\ character strings can be specified for using escape sequences
•	This is also used for specifying multi-byte characters


Parameters and Commands 
Rarely Used Parameters
•	WARN_RECREATE_FILES = TRUE
•	If true, log warning message when files are overwritten
•	If false, suppress warning messages

•	WRITABLE_DATAFILES = FALSE
•	If false (default), DUL is ensured to be READ-ONLY
•	If true, DUL can do some limited datafile editing in command mode
Parameters and Commands 
Undocumented Parameters
•	_SLPE_DEBUG=FALSE
•	ASM_DO_HARD_CHECKS = TRUE
•	AUTO_UPDATE_CHECKSUM = TRUE
•	AUTO_UPDATE_TRAILER = TRUE
•	CF_FILES = 1022
•	CF_TABLESPACES = 64
•	DEFAULT_CHARACTER_SET = 
•	DEFAULT_NATIONAL_CHARACTER_SET = 


Parameters and Commands 
Undocumented Parameters
•	DB_ID =
•	DB_NAME =
•	FEEDBACK = 0
•	OSD_MAX_THREADS = 1055
•	SCAN_DATABASE_SCANS_LOB_SEGMENTS = TRUE
•	SCAN_STEP_SIZE = 512
•	TRACE_FLAGS = 0





Parameters and Commands 
Undocumented Parameters
•	UNEXP_MAX_ERRORS = 1000
•	UNEXP_VERBOSE = FALSE
•	USE_LOB_FILES = FALSE
•	VERIFY_NUMBER_PRECISION = TRUE

•	Although functions of some of the undocumented parameters may be intuitive, it is recommended to first e-mail and ask Bernard to be sure.

Parameters and Commands 
Most Useful Commands
•	[ALTER SESSION] SET init.dul parameter =  value ;
•	Most parameters can be changed dynamically
•	BOOTSTRAP;
•	This scans the data dictionary and builds external files used for mapping USERs, TABLES, EXTENTS, and COLUMNS during later UNLOAD commands.  
•	Only functions if SYSTEM.dbf is available  
•	DESCRIBE  owner_name.table_name ;
•	REM any_text_till_end_of_line 
•	REM  is NOT allowed inside ddl statements 

Parameters and Commands 
 Most Useful Commands
•	SCAN DATABASE;
•	Scans all blocks of all configured data files. 
•	Two or three files are generated
•	SEG.dat
–	found segment headers 
•	EXT.dat
–	contiguous table/cluster data blocks
•	SCANNEDLOBPAGE.dat
–	information for each lob datablock
–	If SCAN_DATABASE_SCANS_LOB_SEGMENTS=TRUE
Parameters and Commands 
 Most Useful Commands
•	SCAN TABLES;
•	Uses SEG.dat and EXT.dat as input.        
•	Scans for all tables in all data segments (a header block and at least one matching extent with at least 1 table).

•	SCAN EXTENTS;
•	Uses SEG.dat and EXT.dat as input.
•	All extents for which no corresponding segment header has been found.  Only useful if a tablespace is not complete, or a segment header is corrupt.

Parameters and Commands 
Most Useful Commands
•	SHOW DBA dba ; 
•	dba to file_no block_no calculator	   
•	SHOW DBA  rfile_no block_no ;  
•	file_no block_no to dba calculator	   
•	SHOW SIZES ;                   
•	shows size of important structures	   
•	SHOW PARAMETER;                
•	shows the current values of all parameters	   
•	SHOW LOBINFO;                  
•	shows lob indexes found with SCAN DATABASE       
Parameters and Commands 
Most Useful Commands
•	SHOW DATAFILES; 
•	summary of configured datafiles       
•	SHOW ASM DISKS; 
•	summary of configured asm disks       
•	SHOW ASM FILES; 
•	summary of configured datafiles on asm       
•	SHOW ASM FILE  cid  
•	extent information for asm file

Parameters and Commands 
Most Useful Commands
•	UNLOAD DATABASE;  /* everything except SYS */
•	UNLOAD USER user_name; 
•	UNLOAD [TABLE]  [  schema_name.] table_name  		[ PARTITION ( partition_name ) ] 
			[ SUBPARTITION ( sub_partition_name ) ] 
			[ ( column_definitions) ] 
			[  cluster_clause  ] 
			[  storage_clause  ] ;
Parameters and Commands 
Most Useful Commands
•	UNLOAD EXTENT  table_name               
			[ (  column_definitions  ) ]              
			[ TABLESPACE  tablespace_no  ]               
			FILE  extent_start_file_number      
			BLOCK extent_start_block_number  		BLOCKS  extent_size_in oracle_blocks ; 

Parameters and Commands 
Most Useful Commands
•	UNLOAD LOB SEGMENT FOR 
		[schema_name.]table_name [(column name)] ;
 
•	UNLOAD LOB SEGMENT STORAGE 
		( SEGOBJNO data obj#) ;

•	EXIT, QUIT, EOF, BYE all cause DUL to terminate.
Parameters and Commands 
Rarely Used Commands
•	COMMIT;     
•	Writes the changed blocks to the data file
•	Most of the time, DUL is used as READ-ONLY!
•	CREATE BLOCK INDEX  index_name  ON  device ;
•	A block index contains the address of valid oracle blocks found in a corrupt file system. Useful to merge multiple disk images or to unload from corrupted file systems. 
•	This is only useful in extreme file system corruption scenarios

Parameters and Commands 
Rarely Used Commands
•	DUMP [ TABLESPACE  tablespace_no ]     
			[ FILE  file_no  ]     
			[ BLOCK  block_no  ]     
			[ LEVEL  level_no  ] ;     
•	Not a complete blockdump, mainly used for debugging.     The data block address is remembered.
•	EXTRACT  asm file name  to  output file name  ;  
•	Copies any ASM file from a disk group to the file system.     (there was a problem with online redologs, this needs more testing)
Parameters and Commands 
Rarely Used Commands
•	MERGE block_index INTO [  segment  ];
•	The merge command uses the information in the index file to locate possible data blocks. It looks for a combination of file numbers and object id. 
•	Each candidate block is compared to the current block in the datafile. 
•	If the current block is bad or has an older scn, the candidate will be written into the datafile. 
•	This is only useful in extreme file system corruption scenarios.
Parameters and Commands 
Rarely Used Commands
•	ROLLBACK; 
•	Cancels the UPDATE statements

•	SCAN DUMP FILE  dump file name 
			[ FROM  begin offset  ]
			[ UNTIL  end offset  ];
•	Scans an export dump file to provide the create/insert statements and the offsets in the dump file
Parameters and Commands 
Rarely Used Commands
•	SCAN LOB SEGMENT  storage clause ;
•	SCAN LOB SEGMENT FOR  
				table name  [.  column name] ;
•	Scans the lob segment to produce LOBPAGE.dat information, but ONLY for this segment. 
•	Probably quicker and smaller. 
•	For partitioned objects use SCAN DATABASE;
Parameters and Commands 
Rarely Used Commands
•	UPDATE [ block_address ] 
SET UB1|UB2|UB4 @ offset_in_block = new_value ;

•	UPDATE [ block_address ] 
SET  block element name  = new_value ;        
•	Now and then we can repair something.
•	Patches the current block and dumps it.  
•	You can issue multiple UPDATE commands.  
•	Block is not written yet, use COMMIT to write. 
Parameters and Commands 
Rarely Used Commands
•	UNEXP [TABLE] [  owner. ]  table name        
			(  column list  ) [ DIRECT ]       
			DUMP FILE  dump file name       
			FROM  begin offset  [ UNTIL  end offset  ]       
			[ MINIMUM  min number of cols  			COLUMNS ] ;        
•	To unload data from a corrupted exp dump file. 
•	No special setup required, just the compatible parameter.       
•	The begin offset should be where a row actually begins. 
Parameters and Commands 
Rarely Used Commands
•	UNPUMP       
•	To unload data from a corrupted expdp (datapump) dump file.       
•	This is still a work in progress.  While the basic commands work, it is rather complex to use. 
•	Contact Bernard directly if this is needed.

Quiz
1) DUL is run at a command prompt and can not be run in batch mode.
•	True
•	False
Quiz
2) DUL can run in parallel when used in a batch mode
•	True
•	False


Chapter 4: Simple Scenarios
•	Prereqs: 
•	Intermediate knowledge of Oracle Database Server
•	Use of imp utility, interactive and batch modes
•	Use of SQL*Loader 
•	General knowledge of UNIX/Windows command level
•	vi or other text editor on UNIX
•	WordPad on Windows

Simple Scenarios
Agenda
•	Simple Data Recovery 
•	Full Database Data extract
•	Partial Database Data extract
•	Schema Data extract
•	Table Data extract
•	Extent Data extract
•	Data Dictionary extract
Simple Scenarios
Assumptions / Process
•	The SYSTEM.dbf datafile is available and not corrupt

•	The engineer doesn’t need to know anything about the application tables structure, column types etc...

•	The metadata (user names, table names, column names, column types) are read from the SYSTEM.dbf with the BOOTSTRAP; command.	                     
•	Information generated during the BOOTSTRAP command is stored in OS text files and can be read by subsequent DUL sessions.
Simple Scenarios
Full Database Extract
•	Unloading the entire database with all available .dbf files will generate output for all schema (except SYS) even ones you may not be interested in (i.e. SYSTEM, XDB, MDSYS, OUTLN, etc)

•	Configure init.dul and control.dul
•	Run /dul
	DUL>bootstrap;
	DUL>unload database;
	DUL>exit
Simple Scenarios
Full Database Extract
While a Full Database Extract may be the fastest way to get some kind of result (particularly if customer is in a hurry), it will also create many more files than needed.

•	 If disk space is an issue for the customer (in the case of a very large database), creating too many files could be a problem

•	 Doing a Full Database Extract will take the maximum amount of time because each table extract is done serially
Simple Scenarios
Full Database Extract
Best Practice: Know exactly what data is critical for the customer and limit the DUL extract run.
•	 Limit configured dbfs in control.dul to only those that contain data the customer needs.
•	 DUL will save time by not scanning unnecessary dbfs

Best Practice: DUL does not automatically run in parallel, however multiple Partial Database Extract sessions can run in parallel if properly configured to save time.

Simple Scenarios
Partial Database Extract
•	Best Practice: To save time, eliminate dbfs from the control.dul that don’t contain critical data. These are typically UNDOTBS, SYSAUX, IDX, INDEX, TEMP, etc
•	The customer may identify other unnecessary dbfs

•	Configure init.dul and control.dul
•	Run /dul
	DUL>bootstrap;
	DUL>unload database;
	DUL>exit


Simple Scenarios
Partial Database Extract
While the commands for a Partial Database Extract may be the same as a Full, DUL is only aware of the .dbf files in the control.dul and consequently will limit output

•	 DUL will output an error message for objects with referenced tablespaces found in the data dictionary, but have no corresponding .dbf in the control.dul
•	 These errors can be ignored, although you may have to explain them to the customer

Simple Scenarios
Partial Database Extract
•	Best Practice: If the customer is uncertain about the contents of their application .dbf files, leave them in the control.dul, otherwise data may be missed

•	To save time, consider running parallel DUL sessions with each configured for a different schema or a different subset of tables (if the database is large)
•	If running multiple DUL sessions, consider running from separate directories to avoid overwriting dul.log



Simple Scenarios
Partial Database Extract
•	Another scenario requiring a Partial Extract would be that a customer has a single tablespace that has gone offline.  Possibly only one of it’s datafiles is corrupt.
•	In this case, only include the dbfs for that tablespace (and system) and exclude all others from control.dul
•	Configure init.dul and control.dul
•	Run /dul
	DUL>bootstrap;
	DUL>unload database;
	DUL>exit

Simple Scenarios
Partial Database Extract
•	Best Practice: To eliminate many error messages and also save time, consider extracting at the schema or table level if the customer is able to be specific.

•	Note: In many real world scenarios, the database may not be down.  The data to be extracted may be a very small portion of the entire database.
•	A truncated table
•	A dropped user
•	A corrupted tablespace
Simple Scenarios
Schema Data Extract
•	Unload only the schema that the customer needs. 

•	Configure init.dul and control.dul
•	Run /dul
	DUL>bootstrap;
	DUL>unload USER scott;
	DUL>unload USER apps;
	…
	DUL>exit
Simple Scenarios
Table Data Extract
•	Unload only the exact tables that the customer needs

•	Configure init.dul and control.dul
•	Run /dul
	DUL>bootstrap;
	DUL>unload TABLE scott.dept;
	DUL>unload TABLE apps.po_orders;	
	…
	DUL>exit


Simple Scenarios
Table Data Extract
•	There are optional parameters to the UNLOAD TABLE command which can further limit what data is extracted.
•	UNLOAD [TABLE]  [  schema_name . ]  table_name
[ PARTITION(  partition_name ) ]              
[ SUBPARTITION(  sub_partition_name ) ]              
[ (  column_definitions ) ]              
[  cluster_clause  ]              
[  storage_clause  ] ;
Simple Scenarios
Table Data Extract
•	storage_clause ::=        
 	STORAGE ( storage_specification ) 

•	storage_specification ::= 
        OBJNO object_id_number 
|       TABNO cluster_table_number
|       SEGOBJNO cluster/data_obj_number /*v7/v8 */
|       BLOCK data_segment_header_block_number )  
Simple Scenarios
Extent Data Extract
•	Taking the limits further, data can be extracted by extent (just a partial table, with limited rows)
•	This can be useful when the customer has partial table corruption and has already marked specific rows or blocks as unusable.
•	Configure init.dul and control.dul
•	Run /dul
	DUL>bootstrap;
	DUL>unload EXTENT scott.customer …;
	DUL>exit
Simple Scenarios
Extent Data Extract
•	UNLOAD EXTENT  table_name               
			[ (  column_definitions  ) ]              
			[ TABLESPACE  tablespace_no  ]               
			FILE  extent_start_file_number              
			BLOCK extent_start_block_number               
			BLOCKS  extent_size_in oracle_blocks ;

Simple Scenarios
Data Dictionary Data Extract
•	Since DUL only extracts data, it is up to the customer DBA to reconstruct indexes, triggers, etc from previously saved create scripts.
•	If the customer has not maintained create scripts for these other objects, it may be possible to construct by extracting source code from the data dictionary.
	UNLOAD table sys.source$;
	Note: If this data is extracted, DO NOT load into SYS on another database.  Import this data to a separate schema and write SQL to reverse engineer scripts.
Simple Scenarios
Review Output
•	dul.log
•	All parameter settings for that run are listed
•	db_id and/or db_name found is listed
•	All recognized datafiles are listed along with file#, relative file#,  startblock, #blocks, blocksize, and offset
•	Row counts for each schema.table written
•	Possible warning and error messages 
•	Best Practice: The exact version of DUL for this run is displayed in the header.  If there are any questions, send this log to the [email protected] distribution list

Simple Scenarios
Review Output
•	Extracted files
•	schema_tablename.dmp or .dat or .ctl
•	dul.log example
	Found db_id = 1321768231
	0 1 c:\app\jdydek\oradata\orcl\SYSTEM01.DBF startblock 0 blocks 93441 block size 8192 (off=0)
	4 4 c:\app\jdydek\oradata\orcl\USERS01.DBF startblock 0 blocks 641 block size 8192 (off=0)
	…
	DUL> unload table locationd (col001 number, col002 varchar2(11)) storage (extents (file 4 block 530));
	. unloading table                 LOCATIOND       6 rows unloaded
	DUL> exit



Simple Scenarios
Review Output Messages
•	In general, there is no comprehensive list of warnings or errors that may occur during a DUL session. 
•	Check the on-line user’s guide or e-mail helpdul_nl.
•	Warnings
•	These may typically be ignored, however try to understand why they are occurring.
•	Errors
•	These may cause DUL to terminate, or it may continue on with no results.  Use best judgment from reviewing the output dul.log.
Simple Scenarios
Review Output Typical Errors
•	You need a more recent DUL version for this os
•	Cause: DUL is recompiled approximately every 45 days with a different expiration date.  
•	Download the current available version from website. 
•	If it is current, e-mail Bernard immediately.
•	version GLIBC_2.11 not found (required by dul)
•	Cause: There are 2 versions of DUL for Linux
•	Download and try the alternate version of DUL for Linux (one uses dynamic linked libraries)


Simple Scenarios
Review Output Typical Errors
•	Each table extracted should show a row count but: 

. unloading table    LOGSTDBY$FLASHBACK_SCN
DUL: Error: No entry in control file for block: ts# = 1 rfile# = 2 block# = 2050
DUL: Error: While processing ts# 1 file# 2 block# 2050
DUL: Error: Could not read/parse segment header
       0 rows unloaded

•	Cause: By excluding datafiles like SYSAUX that don’t contain any customer application data, DUL will not find matching tablespaces and blocks that do exist in the data dictionary.  This is expected.
Simple Scenarios
Review Output Typical Errors
•	During startup, you might see:

DUL: Error: open( 'C:\ORACLEXE\ORADATA\XE\SYSTEM.DBF', Read Only)
OS error 2: No such file or directory

•	Cause: A datafile specified in the control.dul is not at the location specified.
•	Either correct the location in the control.dul
•	Or ignore if the file is not really needed and was meant to be excluded.  DUL will continue and not terminate.
Simple Scenarios
Review Output Typical Errors
•	Unsupported feature / data type

DUL: Error: Type REF, typcode 110 is not supported(yet)
0000000000 00220208 6d6aa16a cad6403a b6c27d8e .".. mj.j ..@: ..}. 

•	Cause: DUL may find data types it doesn’t recognize
•	E-mail the error message to Bernard for an interpretation and impact statement. 
Simple Scenarios
Review Output Typical Errors
•	OS Dependent errors
•	If osd_dba_file_bits size is wrong:
	DUL: Warning: Block[1][2] DBA in block mismatch [4][2] 
	DUL: Warning: Bad cache layer header file#=1, block#=2 

•	If osd_c_struct_alignment is wrong:
	DUL: Warning: file# 0 is out of range
	DUL: Warning: Cannot read data block file#=0, block# = 262145 OS error 2: No such file or directory 

•	If db_block_size is wrong:
	DUL: Warning: Block[1][2] DBA in block mismatch [513][1159680] 
	DUL: Warning: File=1, block 2: illegal block version 2
	DUL: Warning: Block[1][2] Illegal block type[0]
	DUL: Warning: Bad cache layer header file#=1, block#=2
Quiz
1) You must have all .dbf files for the database available for DUL to retrieve customer required data.
•	True
•	False

Chapter 5: Complex Scenarios
•	Prereqs: 
•	Intermediate knowledge of Oracle Database Server
•	Use of imp utility, interactive and batch modes
•	Use of SQL*Loader 
•	General knowledge of UNIX/Windows command level
•	vi or other text editor on UNIX
•	WordPad on Windows
Complex Scenarios
Agenda
•	Assumptions / Process
•	Analyzing the entire database
•	Extract data from truncated table
•	Extract data from dropped table
•	Extract data from deleted table

Complex Scenarios
Assumptions / Process
•	The SYSTEM.dbf file is NOT available or is corrupt
•	Best Practice: Before proceeding check if the customer has an older, backup version of SYSTEM.dbf.  Unless there have been major changes to the database, internal object information may be the same and usable even from an old SYSTEM.dbf.
•	Column data types will be guessed by DUL as it tries to extract, but table and column names are lost
•	The guessed column data types/precision can be wrong
•	dul.log will contain statistics (counts, confidence level)  





Complex Scenarios
Assumptions / Process
•	A functional person with in-depth knowledge about the application and tables is required
•	The unloaded data does not have any value, if you don’t know from which table it came.
•	DUL will only identify tables by object number
•	DUL will only identify columns by column number

•	Best Practice: DUL generates row counts for each table.  DUL row counts may be matched to tables if the customer has any recent reports with similar information.

Complex Scenarios
Assumptions / Process
•	This process requires at least 2 runs of DUL
•	Run DUL to analyze all objects, data types and create generic UNLOAD commands for each object
•	Review dul.log statistics and object to table mappings and column data types with the customer.  
•	Modify the UNLOAD commands if necessary.
    Note: Actual column names from the customer may be substituted for the generated “Col1, Col2, Col3…”; Table name may be substituted for Object Number at this time.
•	Run DUL to process each modified UNLOAD command by object number, possibly in a batch file

Complex Scenarios
Assumptions / Process
•	Note: DUL will not find ending columns if they only contain NULLs
•	Trailing NULL columns are not stored in the database
•	The number of columns may not match the source table
•	Tables that have been dropped will be found and generate an UNLOAD with valid object number
•	When a table is dropped, the description is removed from the data dictionary only, however rows with the object number will still exist in the datafile.
•	Tables without rows will go unreported
Complex Scenarios
DUL Run 1: Analyze datafiles
•	Configure init.dul and control.dul
•	Be sure USE_SCANNED_EXTENT_MAP=false

•	Run /dul
	DUL>scan database;
	DUL>set USE_SCANNED_EXTENT_MAP=true
	DUL>scan tables;   /* or scan extents */
	DUL>exit
Complex Scenarios
Review dul.log from 1st Run
•	Review statistics and generated UNLOAD commands
•	For each found object number, DUL will: 
•	Display it’s column analysis confidence level statistics
•	Post up to 5 rows of data in plain text 
•	Format a generic UNLOAD command with “best guess” column attributes
•	Tablename will be ‘OBJNOnnn’
•	Columns will be ‘COL001, COL002, etc’
•	Use the plain text to verify the identity of the table and to validate the data types that DUL guessed.

Complex Scenarios
Review dul.log from 1st Run
Analyzing segment: data object id 12088 segment header at ( file 4 block 11)   heap organized table

Col    Seen  Max PCT  PRINT  NUMBERS DATES TIMESTAMP WITH TZ INTRVAL ROWIDS LOB
 no   count Size NUL 75%100% AnyNice AnyNice AnyNice AnyNice Y2M D2S AnyNice
  1       4    2   0   0   0 100 100   0   0   0   0   0   0   0   0   0   0   0
  2       4   22   0 100 100   0   0   0   0   0   0   0   0   0   0  50   0   0

DUL: Warning: No character set id for CHAR Column

"1" "Europe"                                                                    
"2" "Americas"                                                                  
"3" "Asia"                                                                      
"4" "Middle East and Africa"                                                    

UNLOAD TABLE OBJNO12088 ( COL001 NUMBER, COL002 VARCHAR2(22) )
    STORAGE( DATAOBJNO 12088 );

Complex Scenarios
Modifying UNLOAD command
At this time, the generated UNLOAD command can be edited to match customer specifications:

UNLOAD TABLE OBJNO12088 ( COL001 NUMBER, COL002 VARCHAR2(22))
    STORAGE( DATAOBJNO 12088 );

Might become:

UNLOAD TABLE location ( loc_id NUMBER (10), description VARCHAR2(25))
    STORAGE( DATAOBJNO 12088 );

Complex Scenarios
DUL Run 2: Execute UNLOADs
•	Cut and Paste each relevant UNLOAD command:
•	To another text file for a batch run or
•	To another on-line DUL session if the number of UNLOADS is small and the amount of rows small

/dul
DUL>UNLOAD TABLE location ( loc_id NUMBER (10), description VARCHAR2(25)) STORAGE( DATAOBJNO 12088 );
. unloading table                  LOCATION       4 rows unloaded


Complex Scenarios
Extract Data from Truncated Table
•	Since Oracle 8, every object has 2 object ids.
•	The standard object id is used for tracking dependencies in the data dictionary.
•	The data object id is used to mark the data blocks in a data segment.
•	When an object is created, the two are equal
•	Each time a table is truncated, the data object id is incremented.
•	To get data from before a truncate, you need the previous data object id (may be current object id – 1)
Complex Scenarios
Data Extract from Truncated Tables
•	SQL to identify tables that have been truncated

SELECT name, obj#, dataobj# from sys.obj$ 
where obj# <> dataobj#; 

•	SQL to identify usernames and internal id

SELECT user_id, username from sys.dba_users
order by username;   /* or user_id */
Complex Scenarios
Data Extract from Truncated Table
REM Find truncated objects for a specific userid

set pages 60
col username        format a12 trunc

select d.username,
       o.owner#, o.name, o.obj#, o.dataobj#
  from sys.obj$ o,
       sys.dba_users d
 where o.obj#<>o.dataobj#         /* Truncated? */      
   and o.owner# = d.user_id
   and d.username = upper('&1')   /* For 1st parm */
 order by owner#, name;
Complex Scenarios
Extract Data from Dropped Table
•	Beginning with 10g, Oracle has implemented a recycle bin. It is enabled by default.
•	If the database is up, the customer can recover a dropped table normally:
	Flashback table schema.tablename to before drop;
•	If the database is down or Flashback has not been configured, then the key to extracting data is identifying the correct data object id.
	From the dul.log, you may see multiple objects with similar row counts. The customer will need to identify.    
Complex Scenarios
Extract Data from Deleted Table
Test your understanding of Data UnLoader with the following scenario:
•	Flashback Recovery Area has not been configured or the version of the database does not support flashback
•	When trying to remove an employee, the customer forgets a WHERE clause for employee id and does:
	DELETE from hr.emp;  
	COMMIT;    /* all rows are deleted… now what?  */
•	How should DUL be configured to extract the data deleted from the hr.emp table?
Quiz
•	What steps are required after running DUL with no SYSTEM.dbf datafile available?
•	Review dul.log with customer
•	Identify tables based on row count
•	Modify UNLOAD commands to use proper table and column names
•	Cut / Paste modified UNLOAD commands
•	Rerun DUL and enter each UNLOAD command
•	All of the above

Chapter 6: Loading Data
•	Depending on customer needs, the output from a DUL session could possibly be
•	hundreds of export dump files (*.dmp) 
•	hundreds of SQL*Loader files (*.dat, *.ctl)
•	Some of these are temporary workfiles and can be ignored
•	Or just a few of each
•	hundreds of LOB*.dat or *.ctl
•	These are temporary DUL workfiles and can be ignored
•	Customer usable output will be named in the form of schema_tablename.dmp, .dat or .ctl





Loading Data
Next Steps
•	Once the output files are generated, the ASE would typically disengage and the customer DBA take over. 
•	However some customers may need help loading the data.
•	If many files have been generated, the scripts on the following pages may help to batch them together.






Chapter 7: DUL Internal Files
•	Prereqs: 
•	Intermediate knowledge of Oracle Database Server
•	Use of imp utility, interactive and batch modes
•	Use of SQL*Loader 
•	General knowledge of UNIX/Windows command level
•	vi or other text editor on UNIX
•	WordPad on Windows
•	Access to Excel for importing and parsing files

DUL Internal Files
•	DUL generates 2 types of temporary internal files
•	.dat
•	.ctl
•	Critical internal files used
•	EXT.dat			Extent map
•	SEG.dat			Segment map
•	SEEN_TAB.dat		Found table names
•	SEEN_COL.dat		Found column names
DUL Internal Files
•	EXT.dat and SEG.dat are generated during the initial scan of the database
•	DUL uses these files to scan datafiles for content
•	SEEN_COL.dat and SEEN_TAB.dat are used to produce the object statistical information produced during a scan table/extent operation
•	All files can be used to perform advanced unload recovery operations with DUL
DUL Internal Files
•	EXT.dat  (created during a SCAN DATABASE;)
•	Contains info about contiguous table/cluster data blocks
•	Consists of 9 columns
•	Object ID
•	File# of segment header
•	Block# of segment header
•	File#
•	Block# of the first block after the segment header
•	Number of blocks = block offset with segment pointing to HWM
•	Number of tables, 1 if regular table
DUL Internal Files
•	SEG.dat  (created during a SCAN DATABASE;)
•	Contains info of segment headers
•	Consists of 4 columns
•	Object ID
•	File#
•	Rfile#
•	Block#
DUL Internal Files
•	SEEN_TAB.dat (created during a SCAN TABLE;)
•	Contains info on Table objects found
•	Consists of 6 columns
•	Object ID
•	Table #
•	Block #
•	??
•	# of columns
•	Row count


DUL Internal Files
•	SEEN_COL.dat (created during a SCAN TABLE;)
•	Consists of 16 columns
•	Object ID
•	Table #
•	Column #
•	Field Type
•	Max Internal Size
•	Null found
•	Number of rows
•	75% Character

DUL Internal Files
•	SEEN_COL.dat (continued)
•	100% Character
•	Number
•	% Nice Number
•	% Date
•	% Row ID
DUL Internal Files
Examples
•	SEG.dat
"77876" "4" "4" "522 "
•	EXT.dat
"4" "16777227" "6" "5" "77876" "1" "1" "1" "0“
•	SEEN_TAB.dat  
77876 4 522 0 2 5
•	SEEN_COL.dat
77876 0 1 2 2 F 5 0 0 0 5 5 0 0 0 0
77876 0 2 1 11 F 5 0 5 5 0 0 0 0 3 0

DUL Internal Files
Examples
•	To better understand the object numbers found, the columns found and the row counts, these files may be imported into Excel for analysis

Chapter 8: Exercises / Labs
•	Prereqs: Chapter 1
•	None

•	Prereqs: Chapter 2
•	Access to internal Oracle DUL website

•	Prereqs: Chapters 3-7 
•	Oracle Database 11g installed on laptop or
•	Access to a test/development Oracle 11g database
•	Full DBA administrative privileges (for verification)

Exercises / Labs
•	Chapter 1: Overview
•	none

Exercises / Labs
•	Chapter 2: Basics
•	Verify access to new DUL website, SSO is required
•	https://stbeehive.oracle.com/teamcollab/overview/DUL
•	Bookmark DUL website under Favorites
•	Download DUL for Windows (or preferred platform)
•	Expand zip/gz file to local directory
•	Download and save DUL User’s Guide as a local Word Document 
•	Browse Announcements, Forums/Help, Tasks, WikiPages/All Pages for available information
•	Add yourself to the helpdul_nl distribution list

Exercises / Labs
•	Chapters 3-7: Lab setup steps
•	Note: In a real world scenario, the database may be down, but to simplify lab setup and verification of results, you can keep the database up.  
•	DUL can run against .dbf files whether the database is up or down.
•	Login to your database as SYSDBA and run the following script to create a labuser, some tables under labuser, and a newuser for importing data to.
•	@create


Exercises / Labs
•	Chapter 3: Parameters and Commands 
•	Create an init.dul from copy of the generic_init.dul
•	Modify OSD parameters for your platform
•	Review and modify other parameters as desired
•	Generate a control.dul from the database
•	Run SQL on v$datafiles if the database is mounted
	@control_dul.sql
•	Generate a control.dul from OS, edit as needed
•	Capture a file list of .dbf files from the oradata directory
	/strings CONTROL01.dbf > control.dul 



Exercises / Labs
•	Chapter 4: Simple Data Salvage Scenarios
1) Perform a Full Database Extract using the init.dul and control.dul from Chapter 3 exercises
•	dul < Chap4_Ex1.txt
•	Review the log
•	Review the output directory 
•	Notice how many files were created
•	How many of these are temporary work files?
•	How many of these are usable for loading?
•	Review error messages
•	Did it complete?


Exercises / Labs
•	Chapter 4: Simple Data Salvage Scenarios
2) Perform a Partial Database Extract 
•	Edit the control.dul from Exercise 1
•	Remove SYSAUX01.dbf, UNDOTBS01.dbf, EXAMPLE01.dbf (or similar .dbfs on your db)
•	CleanDir.bat
•	dul < Chap4_Ex2.txt
•	Review the log
•	Notice different error messages.
•	Why?
•	Review how many files were created this time?


Exercises / Labs
•	Chapter 4: Simple Data Salvage Scenarios
3) Perform a targeted Schema extract
•	UNLOAD USER labuser;
•	Check the log for table names and row counts
4) Perform a Table extract
•	UNLOAD TABLE sys.source$;
•	Note: Data from this table may be used to reconstruct source scripts for indexes, triggers, etc.
•	Check the log for row counts and any errors
•	Import and verify all data from Chapter 4

Exercises / Labs
•	Chapter 5: Complex Data Salvage Scenarios
•	@actions   /* truncate, drop, delete tables */
•	Edit control.dul, remove SYSTEM01.dbf
•	dul < Chap5_Ex1.txt
•	Review dul.log
•	Extract some UNLOAD commands from log
•	Modify some UNLOAD commands
•	Run UNLOAD commands
•	Import and verify data from Chapter 5

Exercises / Labs
•	Chapter 6: Loading Data
•	Import extracted .dmp or .dat/.ctl files into a new schema on your test database
•	Run import.bat supplied for import from Windows
•	Review data imported to newuser

•	Chapter 7: Internal Files
•	Parse the ext.dat, seg.dat, seen_tab.dat and seen_col.dat text files into an Excel spreadsheet
•	Review row counts, table column statistics, object nos



Posted

in

by

Tags:

Comments

Leave a Reply

Your email address will not be published. Required fields are marked *