data:image/s3,"s3://crabby-images/b66c0/b66c0e30b24952900a8c49a514f3ccbc916eb116" alt="Creating Flat file with two Headers in Informatica PowerCenter issues-after-qlikview-version-upgrade-on-passive-node-of-production-servers"
FLAT FILE:
A flat file is an ASCII text file which is saved with extension .txt, .csv, etc…
Source Analyzer:
Step 1: Go to tools menu –> Source Menu –> Source analyser files from source menu.
-
- Provide the user ID and Password to connect to the DB and to import required tables.
- Import source data from Database.
data:image/s3,"s3://crabby-images/f73ba/f73bae7df5c7475141272d890fcbb3e0a9b5afd3" alt="Picture99"
Target:
Step 2: Go to tools menu –> target menu –> target files from target menu.
-
- Import Target data from file(.csv,.txt) location or Create the file if no flat file exists as shown in the below steps.
- Go to Targets and select Create Option as shown below Screenshot.
data:image/s3,"s3://crabby-images/775a8/775a8d596d9a37ce636e8fe800b4c68303ffc18f" alt="Picture100"
-
- After click on the Create option the below window will be opened and provide a Target table name and select the appropriate database type and Click on Create as shown below screenshot:
data:image/s3,"s3://crabby-images/52c84/52c84957a3c8e3cd530702226953a93e7f434d48" alt="Picture101"
After creating the Target table, the following empty Table will be created.
data:image/s3,"s3://crabby-images/a1819/a18192dc51440ed1ad6763e119b75f678c6be770" alt="Picture103"
-
- We have to edit the empty Target table by double-clicking and provide the below information by clicking on the Edit button as shown below screen shot and provide the Column names data types:
data:image/s3,"s3://crabby-images/30cf8/30cf8b4bfa88ca727e6e6c53306f3e55359113b7" alt="Picture104"
-
- After Clicking on ok we will see the below screenshot with a respective table of data information. Click on Done.
data:image/s3,"s3://crabby-images/88f8d/88f8db45a08b2bbf80959462456799c50a692de0" alt="Picture105"
Mapping:
Create Mapping with the respective name (ex:m_CUSTOMERFLATFILE), m_ is a naming convention for mapping creation.
Have create two pipelines, one is to generated headers and second is to load actual data.
Flow one:
-
- Pick only one row from source query with below query:
SELECT ID,NAME,AGE,ADDRESS,SALARY FROM CUSTOMERS where rownum<2;
data:image/s3,"s3://crabby-images/a2b0f/a2b0f06f085302894c4e5c3abe799eeefd5ef04a" alt="Picture106"
-
- Next expression transformation adds the names of the fields to variable port in order to generate second header line.
data:image/s3,"s3://crabby-images/20c22/20c224d3db62110eb2cc9a0e56f951a42653364a" alt="Picture107"
-
- Pass that port to the target file.
data:image/s3,"s3://crabby-images/c84c0/c84c0817a704ad14fe5cb4654ddd15d1f64146db" alt="Picture108"
FLOW TWO:
The data load order of the mapping: flow one should run first to create the header, To load the actual data in the flat file please follow the below steps:
-
- Create a second flow to load actual data in the flat file:
data:image/s3,"s3://crabby-images/0cf3d/0cf3dd34b5f79a285631402ea324e21ead3574de" alt="Picture109"
-
- Go to mapping –>then target load plan as shown below.
data:image/s3,"s3://crabby-images/d6175/d617531d88e09e9e0395dd9b38c3e2e3d8afc04c" alt="Picture110"
-
- Make sure flow one is on top as mentioned below by changing the order using side arrow as shown below:
data:image/s3,"s3://crabby-images/362a7/362a7f234363dee9e53ab757f5923abd62ae7b8c" alt="Picture111"
Save mapping.
Workflow Manager:
Workflow:
Go to Workflow manager à to create workflow and session for the mapping process.
Session:
Go to Workflow manager à to create a task for the session in the mapping process.
Create a link between session and worklet as shown in below screenshot. Save the workflow designer.
data:image/s3,"s3://crabby-images/79fdd/79fddce4b0036bb9b152e61bf9b707551e91dc80" alt="Picture113"
EDIT TASK:
Go to Workflow->Rght click on Session-> Edit Mapping->select flow one Target file i.e
Step1:CUSTOMERTABLE->Edit Attribute.
Under header option select “use header command output” then in next row under Header Command write header one which you want to show as first header name (ex: ”echo/creating 2 headers”) as shown below Screen Shot.
data:image/s3,"s3://crabby-images/3e336/3e3362b281d6d8b170d121a5af853a10cf5578bf" alt="Picture114"
Step2: from the flow two target table i.e CUSTOMERTABLE1->Edit Attribute.
Select Append if exists, As shown below screenshot, select ok.
Note: Make sure both flow one and flow two target file names should be the same.
data:image/s3,"s3://crabby-images/b0b5c/b0b5c079b7162d8b357fab4cf5514a1fe0a9bd36" alt="Picture115"
Save Workflow and Right click on Session for getting Workflow monitor for output details, as shown below.
data:image/s3,"s3://crabby-images/2a064/2a064278003fb414b982301652660e2b38cec5d5" alt="Picture116"
OUT PUT:
Please find the below Screen shot for Flat file generated with 2 headers.
data:image/s3,"s3://crabby-images/4873c/4873c9a80d09397deb4c2c3de978e90a34590f92" alt="Picture117"