Processing a header and trailer textfile in Datastage
Example case
The input file in our scenario is a stream of records representing invoices. It is a text file in a header-trailer format and has the following structure:
- A header starts with a letter H which is followed by an invoice number, a customer number, a date and invoice currency
- Every item starts with a letter I which is followed by product ID, product age, quantity and net value
- And the trailer starts with a T and contains two values which fullfill the role of a checksum: the total number of invoice lines and total net value.
Header and trailer input textfile in Datastage:
data:image/s3,"s3://crabby-images/30d89/30d8920cb7e924042580cd8fd9e0fc8b2c488dea" alt="Header and trailer input textfile in Datastage"
data:image/s3,"s3://crabby-images/30d89/30d8920cb7e924042580cd8fd9e0fc8b2c488dea" alt="Header and trailer input textfile in Datastage"
Solution
Datastage job design which solves the problem of loading an extract structured into headers and items:
data:image/s3,"s3://crabby-images/b3dbd/b3dbdd3163c2bcd7c54b7c68e3a7468d7a64d1ca" alt="Datastage job design which solves the problem of loading an extract structured into headers and items"
data:image/s3,"s3://crabby-images/b3dbd/b3dbdd3163c2bcd7c54b7c68e3a7468d7a64d1ca" alt="Datastage job design which solves the problem of loading an extract structured into headers and items"
Detailed illustration of each component of the job
The transformer reads first character of each line to mark records and divide them into kinds:
data:image/s3,"s3://crabby-images/088c7/088c785ed07dd4fcf6fa0bdabf8f2a2c9ce54dc1" alt="The transformer reads first character of each line to mark records and divide them into kinds"
data:image/s3,"s3://crabby-images/088c7/088c785ed07dd4fcf6fa0bdabf8f2a2c9ce54dc1" alt="The transformer reads first character of each line to mark records and divide them into kinds"
A datastage transformer which assigns headers using a stage variable:
data:image/s3,"s3://crabby-images/646ac/646acf6b748e791b48308cced522c744a835e6bb" alt="A datastage transformer which assigns headers using a stage variable"
data:image/s3,"s3://crabby-images/646ac/646acf6b748e791b48308cced522c744a835e6bb" alt="A datastage transformer which assigns headers using a stage variable"
The following transformer splits the flow into headers and items and reformats records into a corresponding structure:
data:image/s3,"s3://crabby-images/d361d/d361d891520d37fc3fcd56295fdc8ccffe516146" alt="The following transformer splits the flow into headers and items and reformats records into a corresponding structure"
data:image/s3,"s3://crabby-images/d361d/d361d891520d37fc3fcd56295fdc8ccffe516146" alt="The following transformer splits the flow into headers and items and reformats records into a corresponding structure"
Target oracle tables with correctly loaded invoice headers and lines:
data:image/s3,"s3://crabby-images/d669c/d669cc25124326c38f5d19f439110be1dc3964ce" alt="Target oracle tables with correctly loaded invoice headers and lines"
data:image/s3,"s3://crabby-images/d669c/d669cc25124326c38f5d19f439110be1dc3964ce" alt="Target oracle tables with correctly loaded invoice headers and lines"