Data Conversion and Cleansing Methodology
Data Conversion and Cleansing Methodology
Data Conversion and Cleansing Methodology
Leslie M. Tierstein,
W R Systems, Ltd.
Page 1
tracing back from the new structure to the source(s) to development functional and technical experts,
of the data. you’ll need help from legacy system experts. Take
This approach is the most effective means to detect the time to familiarize legacy systems’operations
“dirty” data in a large-volume database to be and MIS staff with the data cleansing effort, and
converted to a new format. It not only targets data the tasks required from them. As part of the
most critical to the development effort; it also planning for cleansing each subsystem’s data,
allows work to be done in the development schedule time for tasks for which legacy system
environment, rather than on the operational staff participation will be required.
system(s) where the legacy applications reside.
Hardware and Software Specifications
Components Specify, install, and configure the hardware and
The data cleansing effort consists of the following software required to carry out the data cleansing
components: and conversion efforts on both the legacy system(s)
and the development machine. For example,
?? Planning and preparation telecommunications links, ftp software, and/or
?? Legacy-to-target database mapping compatible media may be required to transfer data
?? Designing, testing, and executing programs to from a source to target machine. Software may be
detect data which needs to be cleansed required to translate data from EBCDIC to ASCII.
?? Analyzing the results of the data cleansing A new database instance, to contain cleansed and/or
run(s) converted data, needs to be sized and created.
?? Legacy data cleansing, including identifica- More critical, you should have an application to
tion of manual cleansing needs and strategies directly support the cleansing and conversion effort.
for providing missing or incomplete data. This software should be able not only to document
Planning and Preparation the mappings, but also to generate code to
implement the cleansing and conversion programs.
The planning and preparation phase of the data Several COTS (commercial off-the-shelf) packages
cleansing effort consists of the following tasks: are available to do this job. However, these seem
?? Prepare a schedule and work plan. to be quite expensive, and tailored to mainframe
?? Specify hardware and software needed. environments. A good alternative is to consult the
?? Prepare a Configuration Management Plan. Proceedings of the Oracle Development Tools
?? Specify project metrics. Users Group (ODTUG) conferences: several
participants have suggested solutions using
Schedule and Work Plan Designer/2000 and other Oracle-supplied
You can’t realistically start by preparing a detailed development tools.
schedule – there are too many unknowns. Since this Configuration Management Plan
methodology uses a targeted search strategy, the
The Configuration Management (CM) Plan
amount of time required to cleanse data is directly
typically specifies how versions of the software will
proportional to the number and complexity of the
be managed. Be sure the plan includes a detailed
mappings and transforms which must be applied to
procedure for controlling software changes. For
the source data.
example, a Change Control Board (CCB) may be
An especially tricky part of doing any planning is formed to review proposed database changes. This
that the target database is usually a “moving target” is critical to ensure communication between the
– it is being developed at the same time as the software development team and the
cleansing and conversion software, and is always cleansing/conversion team.
subject to change. If the new software is not a
custom application, but a commercially available Metrics
package, such as the Oracle applications, you’re a Specify the criteria to be used to measure the data
little luckier – but flexfields and extensions are still quality and for determining whether the data is valid
subject to change. or needs to be cleansed.
So, start with a project plan and pert chart, showing
tasks involved, dependencies between the tasks, and
the staff required to peform each task. In addition
Page 2
Legacy-Target Mapping into specially designated interface tables. These
tables are processed by concurrent interface
Using a targeted search strategy, analysts familiar programs, which apply the same validation criteria
with the legacy database structure and functionality as the standard application modules, and insert
work together with those developing the target clean data into the application tables. Records
database to determine precisely how each data which fail to meet the validation criteria are marked
element is mapped to its new destination(s). as rejected and can be manually corrected and
reprocessed.
Table-Level Mapping
When no interface tables are available (which will
The first task in the legacy-target mapping is to be true most of the time), legacy data must be
review each table used by each legacy application mapped directly to the tables in the target database.
and to determine if the data in the table is needed in Even when interface tables are provided, it is
the new application. (In this document, the term instructive to initially map the legacy tables to the
“table” is used to indicate a data store, whether it is application tables where the data will end up. This
implemented as a file, database table, or other will make the cleansing requirements more clear to
storage format.) legacy users and developers alike.
It is important to explicitly specify and report on
the source data which is not needed in the target Column-Level Mapping
system, and to note the reason why. This allows The next task in the legacy-target mapping is to
legacy personnel to more effectively review the review each proposed table-level mapping and to
proposed mappings, and gives a level of confidence specify the column mappings between the two
that data hasn’t been overlooked. For example, a tables. During this stage, inconsistencies between
table used as a temporary batch transfer mechanism legacy and target column formats may be detected.
between two applications probably contains data For example, the lengths of character columns may
which duplicates other table contents, and does not not match; or the target column includes domain
need to be cleansed or converted. (“value set”), range, or other validation not applied
The proposed table-level mappings may reveal one- to the legacy data. The nature of the discrepancy, if
to-many or many-to-one mappings. any, and the data “transform” which must be
In a one-to-many mapping, one legacy table yields applied to correct the discrepancy must be noted.
data to populate multiple target tables. This is Column-Level Transforms
typically the case when a database which is not in
third normal form is converted to normalized One of the most difficult cleansing and conversion
structure. tasks is resolving discrepancies between the source
data value and the format and/or semantics
In a many-to-one mapping, multiple source tables specified for its target column. Such discrepancies
contribute data to the same target table. For are typically resolved by transforming the legacy
example, when several “stovepipe” systems are data into a new value.
converted, some data may be duplicate and can be
discarded. Further analysis is always required for Some transforms may be fairly straightforward.
these mappings. Legacy functional and database For example, a set of 2-letter codes could be
experts must determine which set of data is to be changed to an equivalent set of 5-letter codes via a
maintained. Alternatively, analysis may reveal that simple formula (DECODE… ) or lookup embedded
some elements exist in only one source application, in a conversion program.
and need to be added to data retrieved from other The probability for complications is greatly
source(s) to yield all data necessary for the target increased when tables from multiple legacy systems
application. are merged into one target database and/or the
format or structure of primary and foreign key
Target Tables fields must be changed. Examples of some of these
Oracle applications provide “open interfaces”, complications are given in the following sections.
which offer a semi-automated means to populate Consider a legacy system which includes vendors
portions of the application database. Open and contracts, where each contract must track the
interfaces allow users to import detailed transaction responsible vendor. If the format of the vendor
data from external systems. The data is loaded number (the primary key for the vendor table) is
Page 3
invalid for the new system, it must be transformed order in which the legacy data will be delivered to
to a new value. (For example, it may include the developers. At this point, the order is
letters, and the target system supports numeric-only preliminary only. However, it will form the basis
vendor numbers.) Transforming this value only in for the conversion order which is critical. For
the vendor table is insufficient; the foreign key example, in cases where referential integrity must
constraint to the vendor number in the contract be established, the parent side of a relationship
table must also be transformed. To do so, a cross- must be available in order to create the child
reference between the original value and the newly records. In cases when two or more tables hold
assigned value must be maintained. similar or redundant information, determine which
As another example, consider two applications table will be the primary source of data and which,
which use a code for the account type. However, will provide additional records or column values
the same code has different meanings in the two which will update previously created records.
applications. The cleansing/conversion software List of missing data. Based on the target-legacy
must be aware of the source of the data, and mappings specified earlier, determine which data, if
transform the incoming code from only one of the any, appears to be missing from the legacy systems.
source applications to a new value. At this time, “missing data” will be any target table
The supporting software must be able to document which does not have a legacy source, This might
the required transform rules and, eventually, to not be a real problem, but now is the time to find
generate code to implement these rules. this out, by figuring out why the data appears to be
missing. For example
Finding Defective or Missing
Data Type of
Missing Data Resolution
Cleansing the data for each application consists of Represents new Add data entry to the list
the following phases: functionality of startup tasks for the
?? Analysis and conceptual design users
?? Detailed design and coding Relates to system Add to the list of
?? Inspecting legacy data to detect defects configuration (for configuration tasks for
?? Analysis of results of the data inspection example, printers) developers
?? Further data cleansing, if required Really missing! Reexamine the list of
?? Reports on the cleansing effort. legacy tables to be sure
Analysis and Conceptual Design you haven’t missed
anything; if you haven’t,
The analysis and high-level design phase entails the
start planning for getting
tasks listed below.
the data
?? Develop standards.
?? Develop a list of tables to be cleansed.
Sampling Strategy. Develop a sampling strategy,
?? Develop a list of missing tables. to determine an appropriate subset of data to be
?? Develop a sampling strategy. examined in the data cleansing effort. Given time
?? Get the team together. and resource constraints, it will probably not be
Standards. Develop or adopt standards for writing possible to examine every record in the legacy
the cleansing and conversion software. Standards tables. However, by extracting a representative
documents must include naming guidelines, coding sampling of records, the data cleansing task should
standards for all languages to be used, and be able to detect trends. The data could be selected
procedures for writing, reviewing, and accepting by age -- for example, a range of current vs.
software. completed transactions could be examined, or
List of tables to be cleansed. Based on the legacy- records of different types may be included. The
target mappings specified earlier, develop a list of sampling algorithms must ensure that sets of related
the legacy tables to be cleansed. The tables should records are selected (when parent-child
be listed in the order in which they will be cleansed relationships are involved), and that a representative
(and subsequently converted). This will also be the
Page 4
sample of record types (for example, different types you will have to convert data from a database
of inventory items or transactions) is selected. system that is proprietary, obsolete, badly
Teamwork. Part of the high risk of data cleansing documented, machine-dependent, has no ODBC or
is the high degree of teamwork required between other external drivers, and has no published API.
legacy experts, the conversion team, development Extraction Programs. Extraction programs must
personnel, and support personnel. dump the data in the legacy tables to be converted
?? Coordinate with the development team and to a form which can be loaded into the target
database administrator to ensure that the database. In an Oracle environment, the most
database instance and database structures straightforward approach is to produce ASCII
will be in place to receive the data to be fixed-format records which are input to
cleansed and, later, converted. SQL*Loader. The extraction effort is complicated
?? Have conversion team and legacy system by the fact that Oracle has a hard time deciphering
experts formally review the format of the data many machine-dependent datatypes found on
to be extracted, so that the software can be mainframes or other proprietary hardware. Such
produced to match this format. data must be translated to human-readable
?? Make sure everyone (development teams and (EXTERNAL) datatypes. Some legacy systems
legacy system staff) has bought into the may include utilities to do this, but others might
configuration management plan and need to have custom programs written.
procedures. People from all organizations Transfer Programs. Transfer programs copy the
must be in place to monitor changes to the legacy data to the target system where subsequent
target database structure and the structure of cleansing will be performed. Transfer programs
the legacy data extracts, in order to assess the can be as simple as ftp’ing a file from one
impace of these changes on the cleansing and networked computer to another. In an environment
conversion software. including mainframes or networks which are not
Ethernet-based, however, they may get more
Design and Code compex, and require the purchase and configuration
During the design and code phase, the conversion of third-party software.
team has to develop, test, and document software Load Programs. Load programs will be
and/or procedures to: SQL*Loader scripts, which use SQL*Loader
?? Extract data from the legacy tables according control files to load data from a flat, ASCII file into
to the specified sampling strategy the specified database table(s). The SQL*Loader
?? Transfer data from the legacy system(s) to scripts use the options to create a BAD file, to
the system where the cleansing effort will be contain all records which did not successfully load,
conducted. and a LOG file, to log all rows processed. The
?? Load the data into the conversion or open tables into which SQL*Loader inserts the data are
interface tables not part of the target database; rather, they are
?? Find and report on any dirty data or potential temporary tables whose purpose is to hold all data
problems. from the legacy systems in a format accessible by
the Oracle development and query tools.
The methodology for developing these programs
must incorporate an approach that will work, Reports. Write programs to report on any records
efficiently, all the time, with minimal high-tech which were loaded into the temporary tables, but
muss-and-fuss. The chosen methods must be able have defects which would not be acceptable to the
to convert the legacy data from whatever format it’s production database. One program should be
in – proprietary or non-proprietary; hardware- and written for each table-level mapping. The analysis
operating system-dependent or independent; should include:
database or flat file; hierarchical, networked, or ?? the source of the problem (the table and
relational; state-of-the-art or obsolete; ASCII or column from which the defective data was
EBCDIC – into ASCII, human-readable text files. extracted)
These files are then input to the cleansing and ?? the extent of the problem (the percentage of
conversion programs on the target system. Write records in which the problem was detected)
software which is prepared for the worst – assume
Page 5
?? the nature of the defect, and the record in Cleansing Data on the
which it occurred.
Potential defects include but are not limited to:
Legacy System
?? absence of a value in a required field Cleansing the data in place in the legacy systems
?? violation of a range or check constraint would improve the quality of the legacy system
?? violation of a formatting rule data. It would also allow data cleansing to be
?? invalid value for a column which has value performed prior to and independent of the
set (domain) validation. conversion effort.
Producing these reports should be at least partially Cleansing Legacy Data “Automatically”
automated by the support software. For example, if The simplest fix is to write a program to cleanse the
the development effort is using Designer/2000, bad data. The program, which can be run while
domains, ranges, check constraints,and formatting normal operations continue, would change invalid
rules are associated with the column to which they values to valid values. For this strategy to succeed,
apply in the repository. Scripts can be written to the records with faulty data must be identifiable
check that any legacy column mapped to that target based solely on information stored in the row
column meets the specified validation criteria. containing the defective data or in related rows in
Similarly, the Oracle applications repository other tables.
includes information on the value sets and
formatting rules to be applied to database columns. Before such a program is written or run, a legacy
This information is stored in the FND tables, and system expert needs to identify the source of all
scripts can be generated based on the specified rules defective data:
and values. ?? All records in which the defective data occurs
(not just those examined in the sample).
Analyzing Results ?? The program or programs which caused the
defects to be introduced.
The analysis phase will entail the tasks listed below.
The dirty data may have resulted from previous
1. If required, finish designing, coding, and testing unvalidated data entry and/or programming errors
the analysis reports. which have since been corrected. In this case,
2. Run the reports. Print and distribute the replacing defective values with clean data should
resulting analyses. entail no changes to legacy application software,
3. Determine the cause of the defective data and and a cleansing program can be written and run. (If
the extent of the problem. the system has been in operation forever, an aging
analysis might be included in the analysis programs.
4. Based on the nature of the dirty data detected,
Such an analysis might reveal, for example, that
determine the strategy to be used to clean up the
data created before 1978 [really!] is hopeless
defects. Four cleansing strategies are
incomplete. Users might be forced to conclude that
available, depending on where and how the
theyr eally don’t need 20 years of history converted,
cleansing is done:
thereby changing slightly the scope of the
?? Automatic data cleansing on the legacy conversion effort.)
system If the dirty data resulted from defective software
?? Manual cleansing on the legacy system that is still in operation, the software should be
?? Automatic data cleansing on the target identified, and an estimate made for fixing the
system, as part of loading and converting software and cleansing the data. However, if
the data extensive software changes to legacy systems would
?? Manual cleansing on the target system. be required in order operate using the cleansed data,
Means must also be provided to supply any missing it might not be practical (given time and resource
data detected by the analysis. constraints) to correct the data on the legacy
systems. In this case, the cleansing code would
have to be executed as part of the data conversion.
Page 6
Cleansing Legacy Data “Manually” ?? The conversion software automatically
In some cases, the process of correcting the faulty supplies a valid default value.
data cannot be automated. For example, if a field ?? The conversion software automatically
contains an invalid date or is missing data which is supplies an “invalid value” code.
required by the new system, and the record or ?? Personnel manually enter additional data
related records offer no clues as to what the correct which the conversion software must convert.
data should be, it is not possible to write Deriving Valid Default Values
generalized code to correct the problem. Manual
intervention would be required. Analysts would The conversion software can automatically supply a
have to refer to written documents or other records valid default value. This approach is best used if
to determine the correct data. Data could then be the column represents new functionality and/or no
entered via programs which update an individual legacy column can be mapped to the target column.
record with the appropriate value(s). This In this approach, the column is supplied a valid
approach is, obviously, suited primarily to low- value (as agreed upon by legacy and development
volume application and/or cases when the accuracy personnel) and is, therefore, ready for online
of the missing data is critical to functionality. processing. However, analysts reviewing the
converted data cannot differentiate between records
Cleansing Legacy Data in the which originally contained the default value, if any,
and those whose values were altered.
Target Environment This approach can be implemented by supplying an
Data can be cleansed on the development system if appropriate transform formula to the legacy-target
this is the most time- and cost-effective way to column-level mapping. The formula would be a
proceed. Pending the analysis of the causes and simple SQL DECODE (or NVL) statement to
extent of the defective data, the scripts which translate NULL legacy values into the agreed-upon
convert data from the conversion tables to the target target value.
database can be written to correct the data and/or to
supply missing values. SQL*Loader scripts can Using an “Invalid Value” Code
also incorporate simple transforms. The conversion software can automatically supply a
Due the nature and volume of most cleansing and value which is the agreed-upon way to denote an
conversion efforts, it is impractical to include invalid or missing value, but which will be
individual record updates to data that cannot temporarily allowed in the database. For example,
automatically be fixed. In this case, columns can a missing transaction code can be replaced by a
be supplied with default values, so that they do not series of question marks equal in length to the field
violate referential or other integrity constraints size. (The same value must also be added to the
placed on the target database. corresponding value set.) Post-conversion
reviewers can then easily find the discrepancies and
Supplying Missing Column Values correct them, provided the application includes
A legacy column value is classified as “missing” if: software to edit the affected field(s).
This approach can be implemented by supplying an
?? A target-legacy column mapping report
appropriate “transform” formula to the legacy-
reveals that no source column exists for a
target column-level mapping. The formula would
particular legacy column. In this case, all
translate NULL and/or invalid legacy values into
legacy data would be missing the value.
the agreed-upon target value. If the set of invalid
?? The data cleansing analysis reports reveal values is not known, writing the formula may
that some legacy records have null or blank involve programming more complex and time-
values for a column which is required (NOT consuming than that required for supplying default
NULL) in the target table. values, as discussed above.
Various approaches may be taken to supply missing
data. The legacy staff and conversion team need to Manually Supplying Missing Values
determine which approach best suits each instance, In some cases, the conversion software cannot
and to make additional design and implementation automatically supply missing values. This would
decisions, as outlined below. be the case, for example, if the legacy system stored
Page 7
procurements only at a summary level and line item Automatically extracting unique data is easy to
details were required. In such a scenario, a program but fraught with difficulties. For example,
temporary table would be established, and a data a simple INSERT/SELECT could extract project
entry screen provided. All missing data would be codes from a project table:
entered; since the volume of data is likely to be INSERT INTO project_desc
great, this should be done well before the scheduled (proj_code, proj_descr)
cutover. As part of the conversion, this additional (SELECT DISTINCT
(projcode, projcode)
data would be inserted into the production database FROM legacy_projects);
in the appropriate sequence.
The data entry should be done on the target system. This approach has the following difficulties:
This allows legacy personnel to familiarize ?? There is no (automatic) way to supply a
themselves with the new system, and creates the (meaningful) description.
data in a format requiring the least amount of work ?? There is no (automatic) way to verify that
to prepare it for use in the new system. each project code is, in fact, valid in the new
This approach involves the following steps: system.
1. Analysis and Design. Legacy and Manually inserting new rows in the target table(s)
development personnel agree that values are has the obvious drawback that it may be time- and
missing and must be provided manually. labor-intensive. However, it may also be more
2. Development. Development personnel develop accurate.
data definitions and data entry screens to allow
Fixing Non-Normalized Data
entry of the missing values.
What if a value is, paradoxically, not only missing,
3. Deployment. Development personnel install the
but redundant, with no automated way to select
software on machines accessible to legacy
between two or more variants? For example, a non-
personnel, and teach these personnel how to use
normalized design doesn’t include a company table
the screens.
(missing data); instead, it allowed users to enter a
4. Data Entry. Legacy personnel enter the customer (company) name for each invoice, rather
missing information, including the unique than having the invoice refer to a customer. So, the
identifier(s) which relate the new information to legacy data contains four invoices made out to the
the corresponding row already in the legacy customer “ABC Tool”; three to the “ABC Tool
database. Company”; and one each to “ABC Tool Company,
5. Conversion. Development personnel convert Inc.”, and “ABC Tool Co., Inc”. All these invoices,
the additional data to its target format as part of of course, refer to the same company (redundant
the data conversion effort. data). Trying to do a “SELECT DISTINCT” on
these company names would yield four customers,
Supplying Missing Rows where the target table should contain only one.
A row is classified as “missing” if it would be the (The same situation can arise when two normalized
parent record of a row in another table which has a systems must be converted to one target
foreign key constraint to the missing row. For application, and each contains the company name in
example, every project must have a project type. If a different form.)
the corresponding project type is not in the database To resolve this problem, you need to set up a cross-
at the time of the conversion, the project record reference between one or more legacy values and
cannot be converted. the new value to be used in the target system. For
Two approaches are available for supplying such the example above, the solution might look like:
missing data: 1. Create a table definition that looks like:
?? Automatic creation of missing data based
on existing data. (For Oracle application CREATE TABLE cust_xref (
old_cust_name CHAR(40)
flexfields, this corresponds to the capability , new_cust_name CHAR(40)
to “Allow dynamic inserts”.) )
?? Manual entry of missing data.
Page 8
with the primary key consisting of both the old Order of Conversion
and new customer names. Establishing the order in which tables are to be
2. Seed the cust_xref table with each distinct converted is critical. The order is based on the
customer name from the legacy system(s): dependencies between the tables. Typically,
reference tables, containing stable information,
INSERT INTO cust_xref must be loaded first; then, tables which establish
(old_cust_name, primary keys; then tables when have foreign key
new_cust_name)
(SELECT DISTINCT constraints to the base tables.
customer, customer The data cleansing effort and plan laid some
FROM legacy_customer) groundwork for establishing the order in which the
target database must be populated. However, for
3. Write a data entry screen so the users can purposes of full-scale data conversion, inter-
change the new customer name so that all the application dependencies must be examined in more
old customers that really refer to the same detail.
commercial entity have the same new customer
name. Reference Tables
Reference tables are those tables which contain
Old Name New Name reference data which infrequently changes. Data in
ABC Tool ABC Tool Co.
ABC Tool Company ABC Tool Co. such tables is referenced in transaction-based
ABC Tool Co., Inc. ABC Tool Co. tables, but must be established ahead of time. At
the physical level, reference “tables” may be
implemented in any number of ways, as
4. Be prepared to write conversion software that
Designer/2000 domains, Oracle application value
creates one customer record for each distinct
sets, or independent tables.
new_cust_name, assigns a unique identifier to
each customer, and uses this identifier Even once the order of conversion is established,
throughout the system. the mechanism for populating each of the reference
tables must be established. This may be considered
Conversion Methodology in the Conversion Plan or the Deployment Plan, or
may have been done previously as part of
The conversion effort must populate the target prototyping. Previously specified values may have
database with clean data, that meets all validation to be changed or augmented as data cleansing
and referential integrity constraints imposed by the results are collected. Users may, for example,
software and/or the application database. discover a code value which was valid years ago,
since declared inactive, but still is used in some of
Components the historical records they need converted.
The conversion effort consists of the following
components: Data Migration
?? Analysis and high-level design The Conversion Plan may also have to account for
?? Detailed design and coding the potential recovery and/or examination of legacy
?? Testing data that does not need to be converted. Such
?? Deployment (the execution of conversion tables may be migrated to the target database with
code to insert cleansed data into the their current structure intact, to allow continued
production database) accessibility and query via the Oracle tools.
?? Post-conversion reports.
Detailed Design and Coding
Analysis and High-Level In the detailed design and code phase, the software
Design for each table-mapping must be designed,
implemented, unit tested, and documented. Some of
The most critical task of the analysis phase of the the software may have previously been developed
conversion effort is writing the detailed Conversion and tested as part of the cleansing phase; for
Plan. example, SQL*Loader scripts and control files will
Page 9
be reused. However, because the volume of data to Conversion User
be converted is much greater than the data sampled Every Oracle application table include “Row Who”
in the cleansing effort, further optimization of the columns, which track the date the row was created
code and database will be required. Further, the or last changed, as well as the id of the user who
conversion software must incorporate all those performed the change. If row creation and change
transforms that were part of the cleansing effort. data is stored in the legacy table, it will be carried
forward into the target table. If the data is not
Direct Path vs. Record Load
currently maintained, the id of the user who ran the
By default, SQL*Loader loads records into the conversion script, and the date of the conversion
database by doing an INSERT for each record to be will be used as the creation date and id. One or
loaded. SQL*Loader also includes a DIRECT more users must be created for the purpose of
PATH option, which is much faster than the running conversion scripts
default. This option writes multiple records to the
table’s data file, without doing individual SQL Cross-References
INSERT operations. Any indexes are created after Sometimes, the format of a primary key field must
all the data has been loaded. The Direct Path be changed to conform to application standards.
option can only be used if: (This is discussed in the section of this paper on
?? Data in the input (ASCII) file is in order by column-level transforms.) A cross-reference
the primary key of the target table. between the old and new values must be maintained
?? The target table has no associated database during the conversion process, to enable records
triggers, or the database triggers can be which have foreign key dependencies (via the
temporarily disabled and the trigger activity primary key value) to use the new primary key of
performed by a subsequent program. the converted record. If deemed appropriate by the
users, the original primary key value can be
SQL vs. PL/SQL maintained online after the system goes into
For tables which do not have an Oracle applications production, for example, as part of a comment.
open interface, SQL or PL/SQL scripts must be
written to insert data from the conversion tables Testing
into the production database. These scripts must
prevent the attempted conversion of any data which Testing will incorporate the following phases:
it was previously agreed would be cleansed on the ?? Unit Test
legacy system. The scripts will incorporate any ?? Integration Test
transforms which, it was agreed, could not or would ?? System test or “dry run”
not be performed on the legacy systems.
Unit Test
Processing large volumes of data via SQL
INSERT/SELECT commands is faster, by an order All developers are expected to unit test programs
of magnitude, than processing the same volumes of they have written before the programs are made
data via PL/SQL commands which must use “public”. The unit tests will be performed on small
cursors and perform individual INSERT samples of data. Unit tests can be repeated, if
commands. For this reason, SQL should be the required, with new samples of data which has been
implementation language of choice unless a cleansed in accordance with the findings of previous
conversion requirement which is not supported by cleansing reports.
SQL needs to be implemented.
Integration Test
Reports After all programs have been unit tested, a new,
The design and coding phase must also include the internally consistent sample of cleansed data should
implementation and testing of the post-conversion be produced. The programs will then be run, in the
reports. Such reports can typically be written using order prescribed by the Conversion Plan. Any
SQL*Plus and SQL commands. However, the program errors will be noted and fixed as
Developer/2000 Reports component may be appropriate. Additional data cleansing problems
required. may also be noted.
Page 10
System Test or Dry Run Oracle applications feeder programs. Record
The dry run is the test of the conversion software on the personnel, computer resources, and elapsed
a full-database extract. It is critical to the success time required to perform the conversions and
of the conversion and deployment effort. It provides the effect, if any, on target system performance.
statistics to be used in planning and scheduling the This information will be used to schedule
deployment and in allocating resources to do so. It deployment activities and to pinpoint processes
can also be used to verify that database sizing is whose performance must be improved via
correct, and to allow the database administrator database or application tuning.
and/or application data administrator to tune 7. Examine the results of the conversion, noting
database or table parameters as required before the any software fixes that need to be made to the
production database is configured for online extract, load, or conversion software. To
operation. rigourously review conversion results, test the
The dry run entails the tasks listed below. new applications using the converted data.
1. Revise the extract programs to perform a full- 8. Write up analyses of the dry run.
database extract from the legacy databases. ?? A performance report is required, stating
For both the dry run and system deployment, the time required to perform each task in
the extract files must include all data to be the dry run, broken down for each legacy
carried forward to the target system. file and/or each conversion script.
2. Prepare the production database instance to ?? A cleansing report is required, produced by
accept the data load. Since the dry run involves running the cleansing reports previously
a full-database extract, the production database developed, to report on any dirty which is
may be the only available database which is still too dirty to be successfully converted.
large enough to hold all the data. Develop, test, 9. Determine how any newly detected dirty
and document procedures for returning the data will be fixed – either on the legacy
database to its initial state in order to perform systems, or additional conversion code. Assign
live deployment (or another test). personnel to fix the legacy data, and schedule
3. Extract the cleansed legacy data. During the these fixes.
extraction process, all source databases must be
frozen to ensure that an internally consistent Post-Conversion Reports
snapshot is obtained. Several types of reports must be provided to
4. Transfer the extracted data to the adequately report on possible cleansing and
development machine. Record the personnel, conversion failures.
computer resources and elapsed time required ?? Log files will be produced by SQL*Loader.
to perform the extraction and transfer, and the Such reports specify the number of records
effect, if any, on performance on the legacy and loaded by SQL*Loader, and the number, if
target systems. This information will be used any, rejected, and the reason.
to schedule the system deployment. ?? Post-conversion reports list all records which
5. Load the data into the conversion or interface were loaded into the temporary tables, but
tables using the SQL*Loader programs which failed to be converted into their target
previously written and tested. Record the format.
personnel, computer resources, and elapsed
time required to perform the load and the effect, SQL*Loader Logs
if any, on performance on the production A detailed example of the SQL*Loader log file
system. This information will be used to format is given in the Oracle 7 Server Utilities
schedule deployment activities. For example, if Manual, in the section on the “SQL*Loader Log
loads degrade online performance, testing and File Reference”. The log file includes:
other activities may have to be curtailed during ?? The name of each column loaded, its
this time, or the load transferred to off-peak character type, and length, as well as its
hours. position in the input file.
6. Run the conversion programs in the specified ?? A list of any records discarded, and the
order. These include both custom programs and reason that the record was not able to be
Page 11
loaded. Reasons for rejection include, but
are not limited to:
? ? unique constraint violation
? ? data type mismatch.
?? Summary information on the table load,
including:
? ? number of rows loaded
? ? number of rows rejected due to
data errors
?? Summary statistics on the load session,
including elapsed run time and CPU time.
Conversion Reports
Custom reports will be run after each custom
conversion program. The reports will include:
?? The legacy-target table mapping which was
implemented by the conversion program.
?? A list of records which did not convert
because of unique constraint violations
?? A list of records which did not convert
because of referential integrity violations,
and the nature of the violation (that is,
which foreign key constraint was violated)
?? A list of records which did not convert, or
for which default values were used,
because of logical integrity constraints (that
is, constraints which are not enforced at the
database level, but are implemented via
Designer/2000 domains or Oracle
applications value sets), and the nature of
the violation.
Oracle-supplied interface tables and programs have
corresponding Interface Transfer Reports. Such
reports list all records which failed to load, and
enumerate the reasons which caused the load to fail.
Conclusion
Page 12
4. Supporting Software
This document outlines the procedures and programs required for running the
Overview
software which comprises the Data Cleansing and Conversion Support application.
Using this software requires that detailed table and column definitions for both the
Assumptions
legacy files and the target tables reside in the Designer/2000 repository. Further, it
requires that users have access to the Designer/2000 software, in order to view,
maintain, and/or report on these table and column definitions. Users must also be able
to run the application, which uses the Oracle tools SQL*Plus and Developer/2000.
The application consists of components designed and developed for two different, but
Prospective
potentially overlapping, sets of users:
Users and
System
Architecture ?? Conversion developers
?? Legacy and functional system experts.
All users, but especially the legacy and functional system experts, will be able to run a
set of provided forms and reports to enter, maintain, or report on:
Conversion system developers will have access to other components of the support
application. These components are, essentially, programs which generate programs.
For example, based on column-level legacy-to-target mappings and the validations
defined for the target columns, a support application will generate a cleansing script
for each legacy-to-target table mapping. The script will check each field in each
record in the legacy extract file against the validation rules specified both in the
Designer/2000 repository and the transforms specified in the column-level mappings.
The generated script is then run, to yield the detailed cleansing analysis.
Page 13
4.1 Data Cleansing and Conversion Tasks
The data cleansing and conversion effort will comprise the tasks summarized below,
Overview
and explained in detail in the following sections. The tasks are listed in roughly
chronological order. However, it is anticipated (and planned) that some tasks should
overlap, and that some tasks may be ongoing, as additional information is gathered.
Step Action
1 Review legacy-target table level mappings, to ensure their accuracy and
completeness.
?? Use the Legacy Tables Report to list, by application, the legacy
tables which are currently specified to be converted.
?? Use the Legacy Table Mapping Report to list mappings
previously entered, sorted by legacy application and table.
?? Use the Target Table Mapping Report to list mappings by
target application and table.
Enter any additions, deletions, or corrections using the Legacy-Target
Table Mapping Screen.
2 Review legacy-target column level mappings, to ensure their accuracy and
completeness.
?? Use the Legacy Column Mapping Report to list mappings
previously entered, sorted by legacy application, table, and
column.
?? Use the Target Column Mapping Report to list mappings by
target application, table, and column.
Enter any additions, deletions, or corrections using the Legacy-Target
Column Mapping Screen. Enter any additional target validation rules
using the standard Designer/2000 Edit Table dialogs or property sheets.
3 Based on the legacy table definitions in the Designer/2000 repository,
generate SQL DDL scripts which will define the tables which will hold
data loaded from legacy extract files in an Oracle database. The ability to
generate DDL is provided by Designer/2000.
4 Based on the legacy table definitions in the Designer/2000 repository,
generate SQL*Loader scripts which will load data from legacy extract
files into the corresponding table. Use the Generate Loader Script
program to generate scripts for either a specified table-level mapping or
for all mappings.
5 Determine a sampling strategy, by which legacy system experts will
extract a subset of records from the legacy databases for use in the
preliminary data cleansing. Produce extract files as specified. Transfer
these extract files to the development system.
Page 14
Overview (continued)
Step Action
6 Run the generated DDL scripts to define legacy tables and the
SQL*Loader scripts to load the tables with extracted legacy data.
7 Based on the legacy-target mappings, target validations, and mapping
transforms, generate data cleansing analysis scripts for each table-level
mapping. Use the Generate Cleansing Script program to generate scripts
for either a specified table-level mapping or for all mappings.
8 Run the generated cleansing scripts. Each script examines the extracted
data, to determine which column-level legacy data violates the mappings
and transforms specified. A report is generated for each script run. These
reports are then printed to yield preliminary data cleansing results.
9 Review preliminary data cleansing results, to determine where dirty data
exists and how it will be fixed. Update table and column level mappings
and transform rules as appropriate. Write cleansing programs on the
legacy systems if required.
10 Based on the legacy-target mappings, target validations, and mapping
transforms, generate conversion scripts for each table-level mapping which
is not handled by an Oracle-provided interface file. Use the Generate
Conversion Script program to generate scripts for either a specified table-
level mapping or for all mappings.
11 Based on a detailed analysis of conversion requirements, write any
additional programs or data definitions that cannot be generated
automatically, and apply any required customization to generated
programs. Anticipated hand-coding includes views to SELECT
DISTINCT rows from specified tables; and PL/SQL scripts, when SQL
does not provide the capabilities required to perform a particular
conversion. View and code definitions will be stored in the Designer/2000
repository and generated.
12 Based on the legacy-target mappings, target validations, and mapping
transforms, generate conversion reports for each table-level mapping
which is not handled by an Oracle-provided interface file. Use the
Generate Conversion Report program to generate programs for either a
specified table-level mapping or for all mappings.
Page 15
Overview (continued)
Step Action
13 Using either the previously defined sampling strategy or a refined version
of the strategy, for example, to examine more legacy data, produce another
set of extract files to be used in the conversion. Transfer these extract
files to the development system. Transfer the data from the extract files to
the Oracle database load tables via the previously generated SQL*Loader
scripts.
14 If required, regenerate the cleansing scripts to incorporate any additional
mappings and/or rules specified as a result of the review of data cleansing
results performed in step 9. Run all cleansing scripts on the new versions
of the extract files, to verify that legacy system cleansing and/or revised
mappings and rules have been applied correctly. Generate the cleansing
reports and distribute for analysis.
15 Ensure that a target database has been created to hold the results of the
conversion. For custom conversions, run the conversion scripts, to
transfer the data from the load tables to the specified target tables. For
Oracle-provided interfaces, run the interface programs.
Page 16
4. 2 Software Inventory
The Data Cleansing and Conversion Support Application consists of the proprietary
Overview
software programs listed below.
Page 17
Overview (continued)
Page 18
4.3 Using the Data Cleansing and Conversion Software
This section gives general rules for using the data cleansing and conversion software.
Overview
All data entry and inquiry screens use a standard menu bar. The menu bar includes
Push Buttons
most actions needed to enter and review data. In addition, push buttons have been
and Menu
included at the top of the screen to facilitate screen usage. These buttons provide
Options
shortcuts for actions which are also available on the menu bar. Usage of these buttons
is summarized below.
Button Action
Return to the previous record in a multi-row block.
Advance to the next record in a multi-row block.
Enter query mode.
Execute a query to retrieve legacy-target mappings based on
the currently entered query criteria.
Used on multi-page forms to navigate between pages.
Commit any outstanding transactions.
Page 19
4.4 Legacy-Target Table Mapping
Mapping a legacy table to one or more target tables is the first step is designing and
Introduction
implementing a data cleansing strategy.
Screen Display
Page 20
Follow the procedure below to enter legacy-target table mappings.
Procedure
Step Action
1 Start the program by running the form on Phase2:
H:\appbulletin\tab10020.fmx. Enter your user name and password and
connect to the database CPMD.
2 To review data previously entered, execute a query to retrieve the records
of interest.
3 To enter a legacy table name, you may either type the name, or press List-
of-Values (F9) to view a list of all legacy tables, find one or more of
interest, and select the desired table. Legacy tables are restricted to the
applications CPICS, CAPS, CENTRAK, PACMAN, and CBS.
4 To enter a target table name, you may either type the name, or press List-
of-Values (F9) to view a list of all target tables, find one or more of
interest, and select the desired table. Target tables are restricted to the
Oracle applications PA, PO, AP, AR, AOL, and GL, and the custom
application CPMS-LDM (logical data model). If a table name seems to
appear more than once (as it may, because of inconsistencies in the
CPMS_LDM application), select the first one on the list and/or the one
which is spelled corrected (PA_TASKS, not PA_TASKSES).
5 Enter a comment. At a minimum, enter your initials and the date the
mapping was made. You may also enter comments, questions, open
issues, or other appropriate remarks.
6 Press [Commit] at judicious intervals to save your work.
7 Once entered, a mapping cannot be modified (although the comment can
be changed). To modify a mapping, delete the original by locating it and
using the menu entry Record->Remove, and then enter the replacement.
Page 21