1.What is the difference between rollup and scan?
Ans:
By using rollup we cant generate cumulative summary records for that we will be
using scan.
What is the difference between partitioning with key and round robin
Ans: PARTITION BY KEY:
In this, we have to specify the key based on which the partition will occur. Since it is
key based it results in very well balanced data. It is useful for key dependent
parallelism.
PARTITION BY ROUND ROBIN:In this, the records are partitioned in sequential way,
distributing data evenly in blocksize chunks across the output partition. It is not key
based and results in well balanced data especially with blocksize of 1. It is useful for
record independent parallelism.
2.How do you truncate a table
ans: There are many ways to do it.
1. Probably the easiest way is to use Truncate Table
2. Run Sql or update table can be used to do the same thing
3. Run Program
3.What is the difference between a DB config and a CFG file?
Ans;
A .dbc file has the information required for Ab Initio to connect to the database
to extract or load tables or views. While .CFG file is the table configuration file created
by db_config while using components like Load DB Table
4.Types of parallelism in detail.
ans:
There are 3 types of parallelism in ab-initio.
1) Data Parallelism: Data is processed at the different servers at the same time.
2) Pipeline parallelism: In this the records are processed in pipeline, i.e. the
components do not have to wait for all the records to be processed. The records that
got processed are passed to next component in pipeline.
3) Component Parallelism: In this two or more components process the records in
parallel.
Component parallelism:- A graph with multiple processes running simultaneously on
separate data uses component parallelism.
Data parallelism :- A graph that deals with data divided into segments and operates on
each segment simultaneously uses data parallelism. Nearly all commercial data
processing tasks can use data parallelism. To support this form of parallelism, Ab Initio
provides Partition components to segment data, and Departition components to merge
segmented data back together .
Pipeline parallelism :- A graph with multiple components running simultaneously on
the same data uses pipeline parallelism. Each component in the pipeline continuously
reads from upstream components, processes data, and writes to downstream
components. Since a downstream component can process records previously written
by an upstream component, both components can operate in parallel. NOTE: To limit
the number of components running simultaneously, set phases in the graph.
5.What is the function you would use to transfer a string into a decimal?
Ans:
For converting a string to a decimal we need to typecast it using the following
syntax,
out.decimal_field :: ( decimal( size_of_decimal ) ) string_field;
The above statement converts the string to decimal and populates it to the decimal
field in output.
6.How to execute the graph from start to end stages? Tell me and how to run graph in non-Abinitio system?
6.How to execute the graph from start to end stages? Tell me and how to run graph in non-Abinitio system?
Ans:
There are so many ways to do this, i am giving one example due to time
constraint you can run components according to phasea how you defined.
by creating ksh, sh scripts also you can run.
7.What is data mapping and data modelling?
7.What is data mapping and data modelling?
Ans;
Data mapping deals with the transformation of the extracted data at FIELD level
i.e. the transformation of the source field to target field is specified by the mapping
defined on the target field. The data mapping is specified during the cleansing of the
data to be loaded.
For Example:
source;
string(35) name = "Siva Krishna ";
target;
string("01") nm=NULL("");/*(maximum length is string(35))*/
Then we can have a mapping like:
Straight move.Trim the leading or trailing spaces.
The above mapping specifies the transformation of the field nm
8.What is the difference between sandbox and EME, can we perform checkin and checkout through sandbox/ Can anybody explain checkin and checkout?
8.What is the difference between sandbox and EME, can we perform checkin and checkout through sandbox/ Can anybody explain checkin and checkout?
Ans;
Sandboxes are work areas used to develop, test or run code associated with a
given project. Only one version of the code can be held within the sandbox at any
time.
The EME Datastore contains all versions of the code that have been checked into it. A
particular sandbox is associated with only one Project where as a Project can be
checked out to a number of sandboxes
9.explain the environment varaibles with example.?
9.explain the environment varaibles with example.?
ans;
Environemental variables server as global variables in unix envrionment. They
are used for passing on values from a shell/ process to another. They are inherited by Abinitio as sandbox variables/ graph parameters like
AI_SORT_MAX_CORE
AI_HOME
AI_SERIAL
AI_MFS etc.
To know what all variables exist, in your unix shell, find out the naming convention
and type a command like "env | grep AI". This will provide you a list of all the
variables set in the shell. You can refer to the graph parameters/ components to see
how these variables are used inside Abinitio.
10.What r the Graph parameter?
10.What r the Graph parameter?
ans:
There are 2 types of graph parameters in AbInitio
1. local parameter
2. Formal parameters.(those parameters working at runtime)
11.How to Improve Performance of graphs in Ab initio?Give some examples or tips.?
11.How to Improve Performance of graphs in Ab initio?Give some examples or tips.?
Ans:
There are somany ways to improve the performance of the graphs in Abinitio.
I have few points from my side.
1.Use MFS system using Partion by Round by robin.
2.If needed use lookup local than lookup when there is a large data.
3.Takeout unnecessary components like filter by exp instead provide them in
reformat/Join/Rollup.
4.Use gather instead of concatenate.
5.Tune Max_core for Optional performance.
6.Try to avoid more phases.
12.What are the most commonly used components in a Abinition graph. example of a trasformation of data, say customer data in a credit card company into meaningful output based on business rules?
12.What are the most commonly used components in a Abinition graph. example of a trasformation of data, say customer data in a credit card company into meaningful output based on business rules?
Ans:
The most commonly used components in to any Ab Initio project are
input file/output file
input table/output table
lookup file
reformat,gather,join,runsql,join with db,compress components,sort,trash,partition by
expression,partition by key ,concatinate
13.Difference between conventional loading and direct loading ? when it is used in real time .?
13.Difference between conventional loading and direct loading ? when it is used in real time .?
ans:
Conventional Load:
Before loading the data, all the Table constraints will be checked against the data.
Direct load:(Faster Loading)
All the Constraints will be disabled. Data will be loaded directly.Later the data will be
checked against the table constraints and the bad data won't be indexed.
Api conventional loading
utility direct loading.
14.How to find the number of arguments defined in graph?
14.How to find the number of arguments defined in graph?
Ans: $# - No of positional parameters
$? - the exit status of the last executed command.
15.What is the difference between .dbc and .cfg file?
15.What is the difference between .dbc and .cfg file?
Ans:
.cfg file is for the remote connection and .dbc is for connecting the database.
.cfg contains :
1. The name of the remote machine
2. The username/pwd to be used while connecting to the db.
3. The location of the operating system on the remote machine.
4. The connection method.
and .dbc file contains the information:
1. The database name2. Database version
3. Userid/pwd
4. Database character set and some more...
16.How to do we run sequences of jobs ,,like output of A JOB is Input to B .How do we co-ordinate the jobs?
16.How to do we run sequences of jobs ,,like output of A JOB is Input to B .How do we co-ordinate the jobs?
Ans: By writing the wrapper scripts we can control the sequence of execution of more
than one job.
17•How would you do performance tuning for already built graph ? Can you let me know some examples?
17•How would you do performance tuning for already built graph ? Can you let me know some examples?
Ans:
example :- suppose sort is used in fornt of merge component its no use of using
sort ! bcz we hv sort component built in merge.
2) we use lookup instead of JOIN,Merge Componenet.
3) suppose we wnt to join the data comming from 2 files and we dnt wnt dupliates we
will use union funtion instead of adding addtional component for duplicate remover.
18•What is semi-join
18•What is semi-join
ans:
In abinitio,there are 3 types of join...
1.inner join. 2.outer join and 3.semi join.
for inner join 'record_requiredn' parameter is true for all in ports.
for outer join it is false for all the in ports.
if u want the semi join u put 'record_requiredn' as true for the required component and
false for other components..
19•How to get DML using Utilities in UNIX?
19•How to get DML using Utilities in UNIX?
Ans: If your source is a cobol copybook, then we have a command in unix which
generates the required in Ab Initio. here it is:
cobol-to-dml.
20•what is local and formal parameter?
20•what is local and formal parameter?
Ans:
Two are graph level parameters but in local you need to initialize the value at the
time of declaration where as globle no need to initialize the data it will promt at the
time of running the graph for that parameter.
21•what is BRODCASTING and REPLICATE ?
21•what is BRODCASTING and REPLICATE ?
ans:
Broadcast - Takes data from multiple inputs, combines it and sends it to all the
output ports.
Eg - You have 2 incoming flows (This can be data parallelism or component
parallelism) on Broadcast component, one with 10 records & other with 20 records.
Then on all the outgoing flows (it can be any number of flows) will have 10 + 20 = 30
records
Replicate - It replicates the data for a particular partition and send it out to multiple
out ports of the component, but maintains the partition integrity.
Eg - Your incoming flow to replicate has a data parallelism level of 2. with one partition
having 10 recs & other one having 20 recs. Now suppose you have 3 output flos from
replicate. Then each flow will have 2 data partitions with 10 & 20 records respectively.
22•What is m_dump m_dump command prints the data in a formatted way. m_dump <dml> <file.dat>
23•An exaple of realtime start script in the graph?
22•What is m_dump m_dump command prints the data in a formatted way. m_dump <dml> <file.dat>
23•An exaple of realtime start script in the graph?
Ans:
Here is a simple example to use a start script in a graph:
In start script lets give as:
export $DT=`date '+%m%d%y'`
Now this variable DT will have today's date before the graph is run.
Now somewhere in the graph transform we can use this variable as;
out.process_dt::$DT;
which provides the value from the shell.
24•How to run the graph without GDE?
24•How to run the graph without GDE?
Ans:
In RUN ==> Deploy >> As script , it create a .bat file at ur host directory ,and
then run .bat file from Command prompt
25•How Does MAXCORE works?
25•How Does MAXCORE works?
Ans: Maxcore is a value (it will be in Kb).Whne ever a component is executed it will
take that much memeory we specified for execution
26•.What is $mpjret? Where it is used in ab-initio?
26•.What is $mpjret? Where it is used in ab-initio?
ans:
You can use $mpjret in endscript like
if 0 -eq($mpjret)then
echo "success"
else
mailx -s "[graphname] failed" mailid
27•How do you convert 4-way MFS to 8-way mfs?
27•How do you convert 4-way MFS to 8-way mfs?
Ans:
To convert 4 way to 8 way partition we need to change the layout in the
partioning component. There will be seperate parameters for each and every type of
partioning eg. AI_MFS_HOME, AI_MFS_MEDIUM_HOME, AI_MFS_WIDE_HOME etc.
The appropriate parameter need to be selected in the component layout for the type of
partioning..
28•What is AB_LOCAL expression where do you use it in ab-initio?
28•What is AB_LOCAL expression where do you use it in ab-initio?
ans:
ablocal_expr is a parameter of itable component of Ab Initio.ABLOCAL() is
replaced by the contents of ablocal_expr.Which we can make use in parallel
unloads.There are two forms of AB_LOCAL() construct, one with no arguments and one
with single argument as a table name(driving table).
The use of AB_LOCAL() construct is in Some complex SQL statements contain
grammar that is not recognized by the Ab Initio parser when unloading in parallel. You
can use the ABLOCAL() construct in this case to prevent the Input Table component
from parsing the SQL (it will get passed through to the database). It also specifies
which table to use for the parallel clause.
29•What is mean by Co > Operating system and why it is special for Abinitio ?
29•What is mean by Co > Operating system and why it is special for Abinitio ?
ans:
It converts the AbInitio specific code into the format, which the UNIX/Windows
can understand and feeds it to the native operating system, which carries out the task.
30•How will you test a dbc file from command prompt ?
30•How will you test a dbc file from command prompt ?
ans:
try "m_db test myfile.dbc"
31•Which one is faster for processing fixed length dmls or delimited dmls and why ?
31•Which one is faster for processing fixed length dmls or delimited dmls and why ?
ans:
Fixed length DML's are faster because it will directly read the data of that length
without any comparisons but in delimited one,s every character is to be compared and
hence delays
32•.What are the continuous components in Abinitio?
32•.What are the continuous components in Abinitio?
ans:
Contineous components used to create graphs,that produce useful output file
while running continously
Ex:- Contineous rollup,Contineous update,batch subscribe
33•How to retrieve data from database to source in that case whice component is used for this?
33•How to retrieve data from database to source in that case whice component is used for this?
ans;
To unload (retrive) Data from the database DB2, Informix, or Oracle we have
components like Input Table and Unload DB Table by using these two components we
can unload data from the database.
34• What is the relation between EME , GDE and Co-operating system ?
34• What is the relation between EME , GDE and Co-operating system ?
ans:
EME is said as enterprise metdata env, GDE as graphical devlopment env and Cooperating sytem can be said as asbinitio server relation b/w this CO-OP, EME AND GDE
is as fallows
Co operating system is the Abinitio Server. this co-op is installed on perticular O.S
platform that is called NATIVE O.S .comming to the EME, , its hold the metadata,trnsformations,db config files source and targets information's. comming to GDE its is end user envirinment where we can devlop the
graphs(mapping just like in informatica)
designer uses the GDE and designs the graphs and save to the EME or Sand box it is
at user side.where EME is ast server side.
35•What are kinds of layouts does ab initio supports
35•What are kinds of layouts does ab initio supports
ans:
Basically there are serial and parallel layouts supported by AbInitio. A graph can
have both at the same time. The parallel one depends on the degree of data
parallelism. If the multi-file system is 4-way parallel then a component in a graph can
run 4 way parallel if the layout is defined such as it's same as the degree of
parallelism.
36•Do you know what a local lookup is?
36•Do you know what a local lookup is?
ans:
Lookup File consists of data records which can be held in main memory. This
makes the transform function to retrieve the records much faster than retirving from
disk. It allows the transform component to process the data records of multiple files
fastly.
37•How many components in your most complicated graph?
ans:
This is a tricky question, number of component in a graph has nothing to do withthe level of knowledge a person has. On the contrary, a proper standardized and
modular parametric approach will reduce the number of components to a very few. In
a well thought modular and parametric design, mostly the graphs will have 3/4
components, which will be doing a particular task and will then call another sets of
graphs to do the next and so on. This way total numbers of distinct graphs will
drastically come down, support and maintenance will be much more simplified.
The bottomline is, there are lot more other things to plan rather than to add
components.
38•How to handle if DML changes dynamically in abinitio ?
38•How to handle if DML changes dynamically in abinitio ?
ans:
If the DML changes dynamically then both dml and xfr has to be passed as graph
level parameter during the runtime.
40•Have you worked with packages?
Ans:
Packages are nothing but the reusable blocks of objects like transforms, user
defined functions, dmls etc. These packages are to be included in the transform where
you use them. For example, consider a user defined function like
/*string_trim.xfr*/
out::trim(input_string)=
begin
let string(35) trimmed_string = string_lrtrim(input_string);
out::trimmed_string;
end
Now, the above xfr can be included in the transform where you call the above function
as
include ''~/xfr/string_trim.xfr'';
But this should be included ABOVE your transform function.
For more details see the help file in "packages".
41•What are primary keys and foreign keys?
41•What are primary keys and foreign keys?
Ans:
In RDBMS the relationship between the two tables is represented as Primary key
and foreign key relationship.Wheras the primary key table is the parent table and
foreignkey table is the child table.The criteria for both the tables is there should be a
matching column.
42•What are Cartesian joins?
42•What are Cartesian joins?
Ans:
Cartesian join will get you a Cartesian product. A Cartesian join is when you join
every row of one table to every row of another table. You can also get one by joining
every row of a table to every row of itself.
43•Explain the difference between the “truncate” and "delete" commands?
43•Explain the difference between the “truncate” and "delete" commands?
ans:
Truncate :- It is a DDL command, used to delete tables or clusters. Since it is a
DDL command hence it is auto commit and Rollback can't be performed. It is faster
than delete.
44•How can i run the 2 GUI merge files?
44•How can i run the 2 GUI merge files?
Ans:
Do you mean by merging Gui map files in WR.If so, by merging GUI map files in
GUI map editor it wont create corresponding test script.without testscript you cant run
a file.So it is impossible to run a file by merging 2 GUI map files.
I was looking for the AB Initio Online Training courses and your website really help me in finding my needs. This site contains all the stuff which i was looking . Thanks for this great work and i hope this will help a lots of users to achieve their goals.
ReplyDelete