|
Q1)
What is the physical nature of a database called?
A1)
DBD
Q2)
Is it necessary that all the segments in a Dl/i database have key fields
?
A2)
It is not necessary that all the segments in the database should
have key field, expect for the database.
Q3)
How man key fields and search fields can a segment have?
A3)
One key field and as many search fields in the segment can be declared.
Q4)
Is it necessary that the key field in a Dl/I database be unique?
A4)
No, it is no necessary.
Q5)
What is a key field in an IMS database?
A5)
A Field that DL/I uses to maintain the segments in the ascending
order is called the key field
Q6)
What is a database record?
A6)
A single occurrence of the root along with all its dependents is
called the database record.
Q7)
What is a Hierarchy path?
A7)
A line that starts at the root and passes thru the inter mediate
levels in the hierarchy and ends at the a segment at the bottom of the hierarchy
is called the Hierarchy path.
Q8)
What is a Root?
A8)
The segment at the top of the Hierarchy, which is not a child to
a segment is called the Root.
Q9)
What are Twins?
A9)
Occurrences of all the segment types under a single parent segment
occurrence is called a Twin.
Q10)
Define the terms Parent & Child.
A10)
Parent-Any segment that has one or more segments directly below
it is a Parent. Child-Any segment that has segment directly above it is called the
Child.
Q11)
What is the limitation on the no. of levels in a DL/I database?
A11)
You can have 15 levels in a DL/I database
Q12)
How many sgment types can u have in a DL/I database?
A12)
A Dl/I database can have 255 segment types
Q13)
What is a Segment type?
A13)
Loosely speaking a segment type is a segment in a Dl/I hierarchy
chart.
Q14)
What is a segment?
A14)
A segment is the smallest unit of information that Dl/I uses when
working with information in the database
Q15)
What is Hierarchy Chart?
A15)
A Hierarchy chart is a pictorial representation of the total of
a DL/I database starting from the root, giving all the parent child relationships
that exist within the database
Q16)
what are the control blocks in IMS ?
A16)
There are two control block.1.dbd(database descriptor)2.psb
(program specification block)
Q17)
which is the first statement in COBOL-IMS programs?
A17)
Entry statement is the first statement after procedure division
i.e. ENTRY 'DLICBL' USING .....
Q18)
What is the return code you get after a successful IMS call?
A18)
Spaces.
Q19)
Define DBD?
A19)
DBD : Database Descriptor. IMS Controls the Structure of DB and
access to the DB via DBD. The DBD contains information like, Segment types, their
location in hierarchy and Sequence keys.
Q20)
How can we distinguish between an online and batch program in IMS environment?
A20)
By seeing the IO-PCB in the application program.
Q21)
Which is the DL/I function used in CICS-IMS program?
A21)
PCB(PROGRAM COMMUNICATION BLOCK)
Q22)
What is IMS?
A22)
INFORMATION MANAGEMENT SYSTEM
Q23)
How does one reorg an HDAM IMS database when changing RAPS (Root Anchor
Points)?
A23)
Unload data using current DBD. 2. Delete/define the underlying
VSAM dataset(s). 3. Re-load data using newly-defined DBD with new RAPs. 4. Re-build
any secondary indexes.
Q24)
What do you know about DBD gen?
A24)
used to generate DBDs. The statements in DBDGEN process
are PRINT NOGEN, DBD, DATASET, SEGM, FIELD, DBDGEN, FINISH, END
Q25) What are common DLI
functions?
A25)
GU,GN,GNP,GHU,GHN,REPL,ISRT,DLET...
Q26) What are common status
codes that you come across?
A26)
GE,GB,GD,GK,GP,AI,AB,AC,AK,AJ,AM,AU,DJ,II,IX,QC,QD,H...
GE - segment not found
GB - end of database
Q27) What are the command
codes and their purposes?
A27)
Command codes extends the function of a SSA call. It simplifies
programming and it improves performance.
*C - Concatenated key, D-path call, F- first occurrence, L- last occurrence,
N- path call ignore , P-set parentage.
Q28) What are the parameters
used in CBLTDLI call?
A28)
Function code, PCB mask, Segment I/O Area & SSA(s).
Q29)
What are qualified and unqualified SSA's.
A29)
A Qualified SSA contains Key field as well as search field and
parenthesis An unqualified SSA does not contain key field and parenthesis
Q30) What do you know about
MFS?
A30)
Message Format service , Used to format messages that will be transmitted
to and from display screens.
Q31) What for procopt is
used? List some of them?
A31)
Procopt parameter specifies PROCESSING OPTIONS that define the
type of processing that can be performed on a segment. ex: K, G, L, LS, A ,AS, I,
IS.
procopt=k---means , the segment is key sensitive
procopt=g- the segment is data sensitive
(like read only)
L- Load mode , means we can load data base from
scratch
A- Get, Insert, Delete, Replace- means it allows the program to issue
all those calls
I-insert mode. That means only insert calls with insert mode
can be issued
Q32) What is multi positioning
?
A32)
Multi positioning is an option where by IMS maintains a separate
position on each hierarchical path. when more than one PCBs refer to the same DBD
, it is called Multi positioning.
Q33) What is secondary
indexing?
A33)
Secondary indexing is a feature which allows the program to sequentially
retrieve segments or search for segments in a sequence other than key sequence.
Q34) How many PCB’s can
be coded within a PSB?
A34)
As many(more than one)
Q35) What
is PSB,PCB & ACB?
A35) PSB(Program
specification block): Informs about how a specific program is to be access one or
more IMS DB. It consists of PCB.
PCB (Prg Communication Block): Information to which segment
in DB can be accessed, what the program is allowed to do with those segment
and how the DB is to be accessed.
ACB(Access Control
Block): are generated by IMS as an expansion of information
contained in the PSB in order to speed up the access to the applicable
DBD's.
What is check pointing, sync point?
How do you write a PSB code ?
JOB CONTROL LANGUAGE(JCL)
The following are the most Frequently Asked Questions (FAQS) :
Q1)
What is a Generation Data Group (GDG)?
A1)
Generation Data Group is a group of chronologically or functionally
related datasets. GDGs are processed periodically, often by adding a new generation,
retaining previous generations, and sometimes discarding the oldest generation.
Q2)
How is a GDG base created?
A2)
A GDG base is created in the system
catalog and keeps track of the generation numbers used for datasets in the group.
IDCAMS utility is used to define the GDG base.
Q3)
What is model dataset label(Model DSCB)?
A3)
A model dataset label is a pattern
for the dataset label created for any dataset named as a part of the GDG group.
The system needs an existing dataset to serve as a model to supply the DCB parameters
for the generation data group one wishes to create. The model dataset label must
be cataloged. The model DSCB name is placed on the DCB parameter on the DD statement
that creates the generation data group.
Q4)
How are GDGs concatenated?
A4)
Generation Data Groups are concatenated
by specifying each dataset name and the generation number for all generations of
the generation data group. Otherwise to have all generations of a generation
data group, omit the generation number. The DD statement will refer to all generations.
The result is the same as if all individual datasets were concatenated. If generations
are not on the same volume, this will not work.
Q5)
How is a new GDG coded?
A5)
A new GDG is coded as (+1) after the
dataset name as follows: DSN=JAN.DATA(+1). This will cause all generations to be
pushed down one level at the end of the job.
Q6)
When should DISP=MOD is used?
A6)
DISP=MOD is used to either extend an
existing sequential dataset or to create a dataset if it does not exist. If the
dataset exists, then records are appended to the dataset at the end of the existing
dataset. If the dataset does not exist, the system treats MOD as if it were NEW,
provided that the volume parameter has not been used. If the volume parameter is
used, the system terminates the job and does not create the new dataset. MOD can
be used to add to a dataset that extends onto several volumes. Always specify a
disposition of CATLG with MOD for cataloged datasets, even if they are already cataloged,
so that any additional volume serial numbers will be recorded in the catalog.
Q7)
How is a dataset passed from one step to another?
A7)
A dataset is passed from one step to
another based on what is coded on the DISP parameter. The dataset can only be passed
to subsequent steps if PASS was used on the disposition parameter.
Q8)
How are datasets concatenated?
A8)
Datasets are concatenated by writing
a normal DD statement for the first dataset and then adding a DD statement without
a DDNAME for each dataset to be concatenated in the order they are to be read. The
following is an example of three datasets concatenated:
//YEARDAT DD DSN=JAN.DATA,DISP=SHR
//
DD DSN=FEB.DATA,DISP=SHR
//
DD DSN=MAR.DATA,DISP=SHR
Q9)
What is the difference between the JOBLIB and the STEPLIB statements?
A9) The JOBLIB statement is placed after the JOB statement and is
effective for all job steps. It cannot be placed in a
cataloged procedure. The STEPLIB statement
is placed after the EXEC statement and is effective for that job step
only. Unlike the JOBLIB statement, the
STEPLIB can be placed in a cataloged procedure.
Q10)
Name some of the JCL statements that are not allowed in procs.?
A10) Some of the JCL statements which are not allowed in procedures are:
JOB, Delimiter(_/*), or Null statements
2. JOBLIB or JOBCAT DD statements
3. DD * or DATA statements
4. Any JES2 or JES3 control statements
Q11)
What is primary allocation for a dataset?
A11)
The space allocated when the dataset is first created.
Q12)
What
is the difference between primary and secondary allocations for a dataset?
A12)
Secondary allocation is done when more space is required than what
has already been allocated.
Q13)
How
many extents are possible for a sequential file ? For a VSAM file ?
A13)
16 extents on a volume for a sequential
file and 123 for a VSAM file.
Q14)
What
does a disposition of (NEW,CATLG,DELETE) mean? -
A14)
That this is a new dataset and needs
to be allocated, to CATLG the dataset if the step is successful and to delete
the dataset if the step abends.
Q15)
What
does a disposition of (NEW,CATLG,KEEP) mean? -
A15)
That this is a new dataset and
needs to be allocated, to CATLG the dataset if the step is successful and to KEEP
but not CATLG the dataset if the step abends. Thus if the step abends, the dataset
would not be catalogued and we would need to supply the vol. ser the next time we
refer to it.
Q16)
How
do you access a file that had a disposition of KEEP? -
A16)
Need to supply Volume Serial
Number VOL=SER=xxxx.
Q17)
MOD,
DELETE; What does a disposition of (,DELETE) mean ?
A17)
The MOD will cause the dataset to be
created (if it does not exist), and then the two DELETEs will cause the dataset
to be deleted whether the step abends or not. This disposition is used to clear
out a dataset at the beginning of a job.
Q18)
What
is the DD statement for a output file?
A18)
Unless allocated earlier, will have
the following parameters: DISP=(NEW,CATLG,DELETE), UNIT , SPACE & DCB
Q19)
What
do you do if you do not want to keep all the space allocated to a dataset? - GS
A19)
Specify the parameter RLSE (
release ) in the SPACE e.g. SPACE=(CYL,(50,50),RLSE)
Q20)
What
is DISP= (NEW,PASS,DELETE)?
A20)
This is a new file and create it, if
the step terminates normally, pass it to the subsequent steps and if step abends,
delete it. This dataset will not exist beyond the JCL.
Q21)
How
do you create a temporary dataset? Where will you use them?
A21)
Temporary datasets can be created either
by not specifying any DSNAME or by specifying the temporary file indicator as in
DSN=&&TEMP. We use them to carry the output of one step to another step
in the same job. The dataset will not be retained once the job completes.
Q22)
How
do you restart a PROC from a particular step?
A22)
In job card, specify RESTART=PROCSTEP.STEPNAME
where PROCSTEP = name of the JCL step that invoked the PROC and STEPNAME = name
of the PROC step where you want execution to start
Q23)
How
do you skip a particular step in a proc/JOB?
A23)
Can use either condition codes or use
the jcl control statement IF (only in ESA JCL)\
Q24)
A
PROC has five steps. Step 3 has a condition code. How can you override/nullify
this condition code?
A24)
Provide the override on the EXEC stmt
in the JCL as follows:
//STEP001 EXEC procname, COND.stepname=value
All parameters on an EXEC stmt in the proc such as COND, PARM have to be overridden
like this.
Q25)
How
do you override a specific DDNAME/SYSIN in PROC from a JCL?
A25)
//<STEPNAME.DD>
DSN=...
Q26)
What
is NOTCAT 2 - GS
A26)
This is an MVS message indicating that
a duplicate catalog entry exists. E.g., if you already have a dataset with dsn =
'xxxx.yyyy' and u try to create one with disp new, catlg, you would get this error.
the program open and write would go through and at the end of the step the system
would try to put it in the system catalog. at this point since an entry already
exists the catlg would fail and give this message. you can fix the problem by deleting/uncataloging
the first data set and going to the volume where the new dataset exists(this info
is in the msglog of the job) and cataloging it.
Q27)
What
is 'S0C7' abend? - GS
A27)
Caused by invalid data in a numeric
field.
Q28)
What
is a S0C4 error ? - GS
A28)
Storage violation error - can be due
to various reasons. e.g.: READING a file that is not open, invalid address referenced
due to subscript error.
Q29)
What
are SD37, SB37, SE37 abends?
A29)
All indicate dataset out of space.
SD37 - no secondary allocation was specified. SB37 - end of vol. and no further
volumes specified. SE37 - Max. of 16 extents already allocated.
Q30)
What
is S322 abend ?
A30)
Indicates a time out abend. Your program
has taken more CPU time than the default limit for the job class. Could indicate
an infinite loop.
Q31)
Why
do you want to specify the REGION parameter in a JCL step? - GS
A31)
To override the REGION defined at the
JOB card level. REGION specifies the max region size. REGIonfiltered=0K or
0M or omitting REGION means no limit will be applied.
Q32)
What
does the TIME parameter signify ? What does TIME=1440 mean ?
A32)
TIME parameter can be used to overcome
S322 abends for programs that genuinely need more CPU time. TIME=1440 means no CPU
time limit is to be applied to this step.
Q33)
What
is COND=EVEN ?
A33)
Means execute this step even if any
of the previous steps, terminated abnormally.
Q34)
What
is COND=ONLY ?
A34)
Means execute this step only if any
of the previous steps, terminated abnormally.
Q35)
How
do you check the syntax of a JCL without running it?
A35)
TYPERUN=SCAN on the JOB card or use
JSCAN.
Q36)
What
does IEBGENER do?
A36)
Used to copy one QSAM file to another.
Source dataset should be described using SYSUT1 ddname. Destination dataset should
be described using SYSUT2. IEBGENR can also do some reformatting of data by supplying
control cards via SYSIN.
Q37)
How
do you send the output of a COBOL program to a member of a PDS?
A37)
Code the DSN as PDS (member) with a
DISP = SHR. The DISP applies to the PDS and not to a specific member.
Q38)
I
have multiple jobs ( JCLs with several JOB cards ) in a member. What happens if I
submit it?
A38)
Multiple jobs are submitted (as many
jobs as the number of JOB cards).
Q39)
I
have a COBOL program that Accepts some input data. How do you code the JCL statement
for this?
( How do you code instream data in a JCL? )
A39)
//SYSIN DD*
input data
input data
_/*
Q40)
Can
you code instream data in a PROC ?
A40)
No.
Q41)
How
do you overcome this limitation ?
A41)
One way is to code SYSIN DD DUMMY in
the PROC, and then override this from the JCL with instream data.
Q42)
How
do you run a COBOL batch program from a JCL? How do you run a COBOL/DB2 program?
A42)
To run a non DB2 program,
//STEP001 EXEC PGM=MYPROG
To run a DB2 program,
//STEP001 EXEC PGM=IKJEFT01
//SYSTSIN DD *
DSN SYSTEM(....)
RUN PROGRAM(MYPROG)
PLAN(.....) LIB(....) PARMS(...)
_/*
Q43)
What
is STEPLIB, JOBLIB? What is it used for?
A43)
Specifies that the private library
(or libraries) specified should be searched before the default system libraries
in order to locate a program to be executed. STEPLIB applies only to the particular
step, JOBLIB to all steps in the job.
Q44)
What
is order of searching of the libraries in a JCL? - GS
A44)
First any private libraries as specified
in the STEPLIB or JOBLIB, then the system libraries such as SYS1.LINKLIB. The system
libraries are specified in the link list.
Q45)
What
happens if both JOBLIB and STEPLIB is specified ?
A45)
JOBLIB is ignored.
Q46)
When
you specify mutiple datasets in a JOBLIB or STEPLIB, what factor determines the order?
- GS
A46)
The library with the largest block
size should be the first one.
Q47)
How
to change default PROCLIB?
A47)
//ABCD JCLLIB ORDER=(ME.MYPROCLIB,SYS1.PROCLIB)
Q48)
The disp in the JCL is MOD and the program opens the file in OUTPUT
mode. What happens ? The DISP in the JCL is SHR and the program opens the file in
EXTEND mode. What happens ?
A48)
Records will be written to end of file
(append) when a WRITE is done in both cases.
Q49)
What
are the valid DSORG values ?
A49)
PS - QSAM,
PO- Partitioned, IS - ISAM
Q50)
What
are the differences between JES2 & JES3 ?
A50)
JES3 allocates datasets for all the
steps before the job is scheduled. In JES2, allocation of datasets required by a
step are done only just before the step executes.
Q51) What are the causes
for S0C1, S0C4, S0C5, S0C7, S0CB abends ?
A51)
S0C1-May
be due to 1.Missing or misspelled DD name
2.Read/Write to unopened dataset
3.Read to dataset opened
output
4.Write to dataset
opened input
5.Called subprogram
not found
S0C4-may be due to
1.Missing Select statement(during
compile)
2.Bad Subscript/index
3.Protection Exception
4.Missing parameters
on called subprogram
5.Read/Write to unopened
file
6.Move data from/to
unopened file
S0C5-May be due to
1.Bad Subscript/index
2.Closing an unopened
dataset
3.Bad exit from a
perform
4.Access to I/O
area(FD) before read
S0C7-may be due to
1.Numeric operation
on non-numeric data
2.Un-initialize working-storage
3.Coding past the maximum allowed sub script
S0CB-may be due to
1.Division by Zero
Q52)
What
are the kinds of job control statements?
A52)
The JOB, EXEC and DD statement.
Q53)
What
is the meaning of keyword in JCL? What is its opposite?
A53)
A keyword in a JCL statement may appear
in different places and is recognized by its name, eg. MSGCLASS in the JOB statement.
The opposite is positional words, where their meaning is based on their position
in the statement, eg. in the DISP keyword the =(NEW,CATLG,DELETE) meanings are based
on first, second and third position.
Q54)
Describe
the JOB statement, its meaning, syntax and significant keywords?
A54)
The JOB statement is the first in a
JCL stream. Its format is // jobname, keyword JOB, accounting information
in brackets and keywords, MSGCLASS, MSGLEVEL, NOTIFIY, CLASS, etc.
Q55)
Describe
the EXEC statement, its meaning, syntax and keywords?
A55)
The EXEC statement identifies the program
to be executed via a PGM= program name keyword. Its format is //jobname EXEC
PGM= program name. The PARM= keyword can be used to pass external values to
the executing program.
Q56)
Describe the DD statement, its meaning, syntax and keywords?
A56)
The DD statement links the external
dataset name (DSN) to the DDNAME coded within the executing program. It links
the file names within the program code to the file names know to the MVS operating
system. The syntax is // ddname DD DSN=dataset name. Other keywords after
DSN are DISP, DCB, SPACE, etc.
Q57)
What
is a PROC? What is the difference between an instream and a catalogued PROC?
A57)
PROC stands for procedure. It
is 'canned' JCL invoked by a PROC statement. An instream PROC is presented within
the JCL; a catalogued PROC is referenced from a proclib partitioned dataset.
Q58)
What
is the difference between a symbolic and an override in executing a PROC?
A58)
A symbolic is a PROC placeholder; the
value for the symbolic is supplied when the PROC is invoked, eg. &symbol=value.
An override replaces the PROC's statement with another one; it substitutes for the
entire statement.
Q59)
What
is RESTART? How is it invoked?
A59)
RESTART is a JOB statement keyword.
It is used to restart the job at a specified step rather than at the beginning.
Q60)
What
is a GDG? How is it referenced? How is it defined? What is a MODELDSCB?
A60)
GDG stands for generation data group.
It is a dataset with versions that can be referenced absolutely or relatively.
It is defined by an IDCAMS define generation datagroup execution.
Q61)
Explain concatenating datasets?
A61)
Datasets can be grouped in a DD statement
one after another, eg. in a JOBLIB statement where the load module can exist in
one of many datasets.
Q62)
What
is the difference between specifying DISP=OLD and DISP=SHR for a dataset?
A62)
DISP=OLD denotes exclusive control
of the dataset; DISP=SHR means there is no exclusivity.
Q63)
What
is MOD and when would you use it?
A63)
DISP=MOD is used when the dataset can
be extended, ie, you can add records at the end of an existing dataset.
Q64)
What are the keywords associated with DCB? How can you specify
DCB information? What is the OS precedence for obtaining that DCB information, ie.
where does the system look for it first?
A64)
The keywords associated with the DCB
parameter are LRECL, RECFM, BLKSIZE and DSORG. The DCB information can be
supplied in the DD statement. The system looks for DCB information in the
program code first.
Q65) How do you designate
a comment in JCL?
A65)
The comment statement is /_/*
followed by the comments.
Q66) What is the meaning
of the EXEC statement keyword, COND? What is its syntax?
A66)
COND specifies the conditions for executing
the subsequent job step. The value after the COND= is compared to the
return codes of the preceding steps and if the comparison is true, the step is bypassed.
(If this answer confuses you, welcome to the club - memorize it and don't ask questions!)
Q67) What is the improvement
to COND= in the latest version of MVS?
A67)
MVS now allows for an IF bracketed
by an END IF around any job step to replace the COND= syntax. Again, if the IF statement
is true, the step is bypassed.
Q68) What is the purpose
of the PARM keyword in the EXEC statement?
A68)
The value after the PARM= specifies
control information to be passed to the executing program of the job step.
Q69)
What is the purpose and meaning of the REGION keyword and what JCL statement
is it associated with?
A69)
REGION specifies the maximum CPU memory
allocated for a particular job or job step. If REGION is in the JOB card,
it relates to the entire job; if in the EXEC statement, it relates to the
job step.
Q70)
What is the purpose and meaning of the TIME keyword and what JCL statement
is it associated with?
A70)
TIME specifies the maximum CPU time
allocated for a particular job or job step. If TIME is in the JOB card, it
relates to the entire job; if in the EXEC statement, it relates to the job
step.
Q71)
What is the meaning of data definition name (ddname) and dataset name
(dsname) in the DD statement?
A71)
Data definition name is the eight character
designation after the // of the DD statement. It matches the internal name specified
in the steps executing program. In COBOL that's the name specified after the
ASSIGN in the SELECT ASSIGN statement. Dataset name is the operating system (MVS)
name for the file.
Q72) How is the keyword
DUMMY used in JCL?
A72)
For an output file DUMMY specifies
that the output is to be discarded. For input it specifies that the file is
empty.
Q73) What does the keyword
DCB mean and what are some of the keywords associated with it?
A73)
DCB stands for data control block;
it is a keyword for the DD statement used to describe datasets. Keywords associated
with it are BLKSIZE, DEN, LRECL and RECFM.
Q74) What is the difference
between BLKSIZE and LRECL?
A74)
LRECL is the logical record length
, where as BLKSIZE is multiples of LRECL
Q75) Can you execute a PROC
from another PROC?
A75)
I
did not know the answer and my interviewer said NO. Later I tried and executed PROC
from a PROC, three levels deep. Manuals do not state any limit on PROC calling PROC,
or nesting.
Q76) What will happen if
you attempt to restart a job in the middle of a JCL // IF .... // ENDIF?
A76)
Job
will fall through to the ENDIF (not executing any steps), then resume execution
with the first step AFTER the // ENDIF.
Q77) How many positional
parameters are there in job statement?
A77)
There
are two position parameters in job statement.
Q78) What are three parameters
you can specify on Job statement as well as on exec stmt ?
A78)
Time,
Region and Cond parameters
Q79) How can you trap abends
in the JCL?
A79)
Use
IF ABEND statement in the JCL.
Q80) How do you restart a
step in JCL?
A80)
Use
RESTART=step name.
Q81) How do you pass parameters
to the program as the job is being executed ?
A81)
By
using 'parm' parameter in exec statement. the value mentioned here should be declared
in linkage section in the program and process thru procedure division. this technique
is very useful when you do not know the parameters at the time of coding the programs.
Q82) Why do you use a control
card?
A82)
A
control card can be a member of a pds or a sequential dataset and is used for storing
the date fields, Definitions of VSAM files....etc. You use control card because
you cannot use a instream procedure in a procedure. Generally you will be calling
a Proc from your Jcl and you cannot code instream procedure in the Proc and so you
will point to the dataset which is called control card.
Q83) How do you submit JCL
via a Cobol program?
A83)
In
your JCL define as //JOBA JOB 1111, JOB1 //STEP01 EXEC PGM=PROG1 //ddname DD SYSOUT=(*,INTRDR)....and
your COBOL(PROG1) should look like this SELECT JCL-FILE ASSIGN TO ddname. Open this
file and write the JCL statements into this file. E.g. MOVE '//TESTJOB JOB 1111,VISVEISH'
TO JCL-REC.MOVE '//STEP01 EXEC PGM=IEFBR14' TO JCL- REC and close this file. Then
TESTJOB will be submitted.
Q84) How do you submit a
JCL under CICS environment ?
A84)
Pass
all the jcl codes to a COBOL variable(should be declare using OCCURS clause) and
the write the line one by one to the spool using CICS commands like SPOOLClose SPOOLOpen
SPOOLWrite . For more help reffer CECI of CICS or CICS manual
Q85) What is the parameter
to be passed in the job card for the unlimited time , irrespective of the job class
?
A85)
TIME=1440
Q86) Definition of COND parameter
in JCL
A86)
COND
is a condition parameter, consists of 2 sub parameters, 1st - return
code from the previous step, 2nd - condition. If COND is true,
the step on which COND is coded will be BYPASSED.
Q87) What is meant by S0C7
system abend code?
A87)
S0C7
- Data exception error - you will get it whenever you are trying to move the low
values or spaces into the numeric field, or compare the numeric fields with low
values, or try to do some arithmetic operations on the low values. To avoid this
you have to always initialize the numeric fields otherwise they will contain the
low values.
Q88) How to pass the temp
dataset form one JOB step to another?
A88)
By
specifying the DISP as PASS for the temp dataset
Q89) What is a COND parameter
in JCL?
A89)
COND
means condition parameter. It is compared with system return code of previous step.//step1
exec pgm=abcd//step2 exec pgm=xyz, cond=(4,lt)step2 will be executed when system
return code of step1 is less than 4.
Q90) Write a jcl to execute
a job by 7 a.m on Jan 20,1986 ?
A90)
THE
code IS : /_/*MAIN DEADLINE=(0700,B,012086)
Q91) How many types of libraries
are there in JCL ?
A91)
Libraries
are of three types.1.Sytem Libraries: SUCH AS SYS1.LINKLIB2.Private Libraries: SPECIFIED
IN A JOBLIB OR STEPLIB DD STATEMENTS.3.Temporary Libraries: CREATED IN A PREVIOUS
STEP OF THE JOB.
Q92) What u mean by include
statement in JCL ?
A92)
An
include statement identifies a member of a pds or pdse that contains. This set of
JCL statements is called an include group. The system replaces the include statement
with the statements in the include group.
Q93) The maximum number of
in-stream procedure you can code in any JCL is ?
A93)
Fifteen(15).
Q94) What you mean by skeleton
JCl?
A94)
Jcl
which changes during run time i.e. the values for the jcl such as pgm name , dd
name will change .ie same jcl can be used for various job, equivalent to dynamic
sql...
Q95) How do you submit a
JCL under CICS environment ?
A95)
Edit
the JCL in Extra partition TDQ and submit the same using some system command (not
sure) under CICS subsystem. This is what i think, please clarify....
Q96) What is JCL ?
A96)
JCL
is Job Control Language and is used for Batch processing. The startup procedures
of OS and standard products like CICS etc are written in JCL. It is interface between
operating system(MVS) & application program. when 2 related programs are combined
together on control statements is called job control language
Q97) What is the max blocksize
for a Tape file?
A97)
It
is 32,760.Based on that we can calculate efficient number of Records in a Block
Q98) What are the basic JCL
Statements for a Job?
A98)
JOB
: Identifies a job and supplies accounting info
EXEC
: Identifies a job step by indicating the name of the program to be executed.
DD
: Identifies a data set to be allocated for the job step
Delimiter(_/*)
: Marks the end of an in-stream dataset
Null(//)
: Marks the
end of a job
Comments(/_/*)
: Provides Comments
PROC
: Marks the
beginning of a procedure
PEND
: Marks
the end of a procedure
OUTPUT
: Supplies options for SYSOUT processing.
Q99) What does the statements:
typrun=scan and typrun=hold do in a JCL statement
A99)
typrun=scan
checks the JCL for errors, typrun=hold holds the job until further notice.
Q100)
Which
is the most widely used batch performance monitor for DB2?
A100)
DB2PM
Q101)
What
is QSAM error usually when it is occurs?
A101)
Usually
it is occurs at the time of job submission.
Q102)
What
is the purpose of include statement in a JCL?
A102)
It
is used as an alternative for STEPLIB. When we specify the dataset name in include
,it will search in all the datasets specified in the include dataset.
Q103)
What
does S0C4 error mean?
A103)
This
error is faced when we execute the COBOL program. The main reason for this error
is that a variable is defined with less characters and we are trying to move data
which is larger than the actual storage space.
Q104)
In
which table PLAN is registered in ?
A104)
RCT
Q105)
What
is GDG?
A105)
GDG
- group of dataset that are logically or chronologically related, referred by name
and a relative generation number - an integer which identifies the generation of
a dataset and is coded in parentheses after dataset name. Absolute GDG name - GxxxxVyy,
where xxxx-absolute gen. number, yy-version number. Can be sequential, direct, partitioned.
(VSAM - no). Must always be cataloged. Advantage - all datasets have the same name
and system keeps track of adding new and retaining previous generations and deleting
oldest successive generation. To create a GDG we create a GDG index in the system
catalog with IDCAMS utility and then a model (prototype, DSCB) on the same volume
to supply DCB information. Empty - when limit is reached all members are removed
from the index, otherwise-only oldest. Scratch-removed members are uncataloged &
deleted, otherwise - removed & uncataloged, but remain in the system (not
members of GDG any more). GDG number is updated at the end of the job. If number
is not specified all generations will be processed from the beginning
Q106)
what
do you mean By spooling? Expand SPOOL?
A106)
This
is managed by JES. This is used for Queuing the Outputs that are intended for Printing
and are first stored in SPOOLDASD. This can be managed Using
Q107)
For
how long a job can be executed continuously in a mainframe ?
A107)
248
DAYS
Q108)
Max.
No of DD statements in a job ?
A108)
3273
Q109)
How
much space OS allocates when you create a PS or PDS?
A109)
56
KB
Q110)
Min
no of member’s (PDS) in one directory block?
A110)
SIX(6)
Q111)
The
maximum number of steps in a job?
A111)
255
Q112)
How
much is memory space involved, when we code BLOCKSIZE,TRK & CYL ?
A112)
One
block constitutes 32KB of formatted memory/ 42KB of Unformatted memory,6 blocks
makes one Track & 15 Tracks makes one cylinder.
Q113)
What
is DSNDB06 ?
A113)
This
is the Place where DB2 Catalog resides
Q114)
What
is the use of DSNDB07 ?
A114)
This
is the area where sorting takes place in DB2
Q115)
What
is DATACOM db?
A115)
It
is a database used with VSE.
Q116)
What
is a Dummy Utility and what it does ?
A116)
IEFBR14
is a Dummy utility and it is used for the sake of EXEC PGM= .... statement in JCL[when
used it wouldn't perform any task]. e.g. While Allocating a dataset you don't have
to run any utility [this could be done by giving disp=new inDD statement]. But for
a PGM name must be given in EXEC statement, it is used.
Q117)
What
3 guidelines do we have to follow when concatenating DD statements?
A117)
Datasets
must be of the same type (disk or tape), All datasets must have the same logical
record length, The dataset with the largest blocksize must be listed first.
Q118)
On
the DD statement, what is the main difference between creating a new sequential
flat file and a partitioned dataset?
A118)
SPACE=(n,m)
for a sequential file, SPACE=(n,m,p) for a PDS where n, m, and p are numbers. The
p designates how many directory blocks to allocate.
Q119)
What
is the difference between IEBGENER, IEBCOPY and REPRO in IDCAMS utility?
A119)
IEBGENER -- This is a dataset
utility for copying sequential datasets which produces a PDS or a member from a
sequential dataset.
IEBCOPY -- This is a dataset
utility for copying one PDS to another or to merge PDSs.
REPRO -- This is for copying
sequential datasets. More or less same as the IEBGENER.
Q120)
How
do you submit JCL via a Cobol program?
A120)
Use
a file //dd1 DD sysout=(*,intrdr)write your JCL to this file. Pl some one try this
out.
Q121)
How
to execute a set of JCL statements from a COBOL program ?
A121)
Using
EXEC CICS SPOOL WRITE(var-name) END-EXEC command. var-name is a COBOL host structure
containing JCL statements.
Q122)
What
is the difference between static call & Dynamic call ?
A122)
In
the case of Static call, the called program is a stand along program, it is an executable
program . During run time we can call it in our called program. As about Dynamic
call, the called program is not an executable program it can executed thru the called
program
Q123)
What
is the difference between catalogue procedure and In-Stream procedure?
A123)
In
Stream procedures are set of JCL statements written between JOB and EXEC statements,
start with PROC and end with PEND statement. Mainly used to test cataloged procedures.
Cataloged procedure is cataloged on the procedure library and is called by specifying
the procedure name on the EXEC statement.
Q124)
What
do you feel makes a good program?
A124)
A
program that follows a top down approach. It is also one that other programmers
or users can follow logically and is easy to read and understand.
Q125)
Can
we browse or edit the GDG dataset if it is a tape entry?
A125)
No,
You can’t edit or browse the GDG if it resides on tape.
Q126)
What
are the maximum and minimum sizes of any CONTROL AREA (VSAM datasets) ?
A126)
Minimum
Size : 1 track Maximum size : 1 cylinder
Q127)
How
to get cursor position from system in CICS environment ?
A127)
Get
it from EIBCURPOS !
Q128)
How
many parameters are there to a DISP statement and what are their uses ?
A128)
There
are three(3) parameters. Parameter 1: current data set disposition(new, shr, old,
mod) Parameter 2: normal close action for data set (catlg, keep, delete) Parameter
3:abend action for data set (catlg, keep, delete).
Q129)
What
is the error code SOC01 indicate ?
A129)
Operation
exception error For e.g. a dataset open error
Q130)
What
is a procedure?
A130)
A
set of precoded JCL that can be modified through the use of parameters or override
cards. Note: Procedures can be catalogued or instream.
Q131)
What
is the difference between specifying DISP=OLD and DISP=SHR for a dataset?
A131)
OLD
specifies exclusive use of a dataset, SHR allows multiple jobs to concurrently access
the dataset Note: When updating a dataset, you would normally use OLD.
Q132)
What
are the three basic types of statements in a jobstream?
A132)
JOB(one
per jobstream)EXEC(one or more per job)DD(one or more per jobstep)
Q133)
What
does SYSIN * indicate?
A133)
Instream
data follows this card and is terminated when followed by a card containing // or
_/* in columns 1 and 2.
Q134)
What
are three major types of JCL statements? What are their functions?
A134)
JOB
- indicates start of jobstream to the operating system and through
parms coded on it, certain details about the
job (time, region,
message level, job accounting data).
EXEC – indicates the
start of execution of a particular job step, be that step a program or a proc.
DD -
is a data definition, which is used to describe the attributes of a
data set (name, unit, type, space,
disposition).
Virtual Storage Access Method (VSAM)
Q1)
What
are the types of VSAM datasets?
A1)
Entry sequenced datasets (ESDS), key sequenced datasets (KSDS)
and relative record dataset (RRDS).
Q2)
How
are records stored in an ESDS, entry sequenced dataset?
A5)
They
are stored without respect to the contents of the records and in the order in which
they are included in the file.
Q3)
What
is a CI, control interval?
A3) A control interval is the unit of information that VSAM
transfers between virtual and auxiliary storage.
Q4)
What
are the distinctive features of a ksds, key sequenced dataset?
A4) The index and the distributed free space.
Q5)
What
is a CA, control area?
A5)
A group of control intervals makes up a control area.
Q6)
What
is a sequence set?
A6)
This is the part of the index that points to the CA and CI of the
record being accessed.
Q7)
What
is the index set?
A7)
This is the other part of the index. It has multiple levels
with pointers that ultimately reach to the sequence set.
Q8)
What
is a cluster?
A8)
A cluster is the combination of the
index, sequence set and data portions of the dataset. The operating system
gives program access to the cluster, ie. to all parts of the dataset simultaneously.
Q9)
What
is the catalog?
Q9)
The catalog contains the names of all
datasets, VSAM and non-VSAM. It is used to access these datasets.
Q10)
What
is an alternate index?
Q10)
An AIX is a file that allows access to a VSAM dataset by a key
other than the primary one.
Q11)
What
is a path?
Q11)
A path is a file that allows you to access a file by alternate
index - the path provides an association between the AIX and the base cluster.
Q12)
What
is the upgrade set?
Q12)
The upgrade set is the list of all AIXes that VSAM must maintain
for a specific base cluster, so that when data in the base cluster is updated, the
AIX files are also updated.
Q13)
What
is free space?
Q13)
Free space is reserved within the data component of a KSDS to accommodate
inserting new records.
Q14)
What
is a VSAM split?
Q14)
If there isn't enough space in the control interval VSAM performs
a control interval split by moving some records to the free control intervals.
If there isn't a free control interval VSAM performs a control area split by allocating
a new control area and moving half of the control intervals to it.
Q15)
What
is the base cluster?
Q15)
The base cluster consists of the data component and the index component
for the primary index of a KSDS.
Q16)
Do
primary key values have to be unique? Do alternate key values have to be unique?
Q16)
Primary key values must be unique; alternate key values need not
be.
Q17)
In
the COBOL SELECT statement what is the ORGANIZATION for a KSDS?
Q17)
The ORGANIZATION is INDEXED.
Q18)
In the COBOL SELECT statement for a KSDS what are the three possibilities
for ACCESS?
Q18)
ACCESS can be SEQUENTIAL, RANDOM or DYNAMIC.
Q19)
What
is the COBOL RECORD KEY clause?
Q19)
The RECORD KEY in the SELECT clause identifies the files primary
key as it will be known to the program.
Q20)
What
is the purpose of the FILE STATUS clause in the SELECT statement?
Q20)
The FILE STATUS field identifies the field that VSAM uses to provide
information about each I/O operation for the file.
Q21)
If
you wish to use the REWRITE command haw must the VSAM file be opened?
Q21)
It must be opened as I/O.
Q22)
Explain the meaning and syntax for the START command.
Q22)
The START command is used read other than the next VSAM record.
A value must be moved into the RECORD KEY. The KEY clause is optional, but
it can be used to specify a relational (equal, less than, etc.) operator.
Q23)
What
is the meaning of dynamic processing?
Q23)
It's rarely used. It means one program uses both sequential
and random processing for a VSAM KSDS file.
Q24)
Name some common VSAM error conditions and codes.
Q24)
They are end of file (10), duplicate key (22), record not found
(23), VSAM logic error (90), open problem (92) and space problem (93).
Q25)
What
is the VSAM-code field?
Q25)
It is a COBOL II enhancement to VSAM batch processing expanding
the FILE STATUS field. It is defined in WORKING-STORAGE as a six byte group
item with three two byte elements, the normal return code, the function code and
the feedback code.
Q26)
What
is a VSAM slot?
Q26)
A relative record dataset (RRDS) consists of a specified number
of areas called slots. Each slot is identified by a relative record number (RRN)
which indicates its relative position in the file.
Q27)
What
is the utility program closely associated with VSAM?
Q27)
IDCAMS, the access method services utility.
Q28)
There are at least seven IDCAMS commands; name and explain each of them
?.
Q28)
ALTER modifies information for a catalog, alternate index, cluster
or path. BLDINDEX builds the alternate index, of course. DEFINE is used
for ALTERNATEINDEX, CLUSTER or PATH. DELETE removes the catalog entry for a catalog,
cluster, alternate index or path. LISTCAT lists information about the dataset.
PRINT prints the dataset contents. REPRO copies records from one file to another.
Q29)
What
are the three levels of definition for the VSAM DEFINE?
Q29)
They are DEFINE CLUSTER, DATA and INDEX.
Q30)
What
is the significance of the SHAREOPTIONS parameter?
Q30)
It specifies how the file may be shared between jobs and between
batch and CICS environments.
Q31)
What
is the meaning of the DEFINE MODEL parameter?
Q31)
It specifies whether Daniela Pestova or Yamila - oops! Wrong models!
The MODEL parameter allows you to model your cluster by modeling it after an existing
cluster.
Q32)
What
is File Status in
VSAM?
Q32)
The FILE STATUS clause of the FILE-CONTROL paragraph allows
for each file to be associated with a file status
key (i.e., the 2-character data item specified in the FILE STATUS
clause). If the FILE STATUS clause is specified for a given
file, a value indicating the status of each I/O operation against that file
is placed in the associated file status key. This value
is stored in the file status key as soon as the I/O operation is completed (and
before execution of any EXCEPTION/ERROR declarative or INVALIDKEY/AT
END phrase associated with the I/O request).
Note: This element may behave differently
when the CMPR2 compiler option is used. The file status key is divided
into two status keys:
the first character is known as file status key 1; the second character
is file status key 2.
Q33) What's a LDS (Linear
Data Set) and what's it used for?
Q33) LDS is a VSAM dataset
in name only. It has unstructured 4k (4096 bytes) fixed size CI’s which do not contain
control fields and therefore from VSAM's standpoint they do not contain any logical
records. There is no free space, and no access from Cobol. Can be accessed by DB2
and IMS fast path datasets. LDS is essentially a table of data maintained on disk.
The 'table entries' must be created via a user program and can only be
logically accessed via a user program. When passed, the entire LDS must be mapped
into storage, and then data is accessed via base and displacement type processing.
Q34)
What
is IDCAMS ?
Q34)
IDCAMS is the Access Method Services program. You run the IDCAMS
program and supply AMS commands thru SYSIN. (examples of AMS commands are DELETE,
DEFINE, REPRO etc..).
|