i declare a Table as OCCURS 2000 TIMES.If the input file
has more than 2000 records will the COBOL program fail?
Answers were Sorted based on User's Feedback
Answer / vidhya
If you compile the Program using SSRANGE = Y then the,
program will fail, if not the program will not fail.
Is This Answer Correct ? | 14 Yes | 0 No |
Answer / giri
Veena, as far as I knw, An OCCURS clause is used to
indicate the repeated occurrences of items of the same
format in a structure. It is nothing to do with the number
of records in the file. As per your question the filed
which you declare in the table occurs 2000 times. And this
is not the number of record. So your program will read all
the records in the input file. You can display any
occurance of the field like FIELD-NAME(1998) will result in
the value stored in that position, i mean to say 1998th
occurance. When you try to read beyond 2000,the program
will abend with SOC4. I hope I have cleared your doubt!
Is This Answer Correct ? | 11 Yes | 0 No |
Answer / cobol will never die
I don't know how one can answer given the lack of
specificity of the question but.... Are we assuming all
records are loaded into the table and no check is made if
the index or subscript is > 2000? In other words are we
loading more than 2000 records data into the program? Can
we also assume this record has numeric definitions?
Given this scenario, and also given the executable code has
no knowledge of a symbolic copybook layout a S0C7 will not
occur as long as the data in the records being loaded is
wholesome. A S0C7 will occur, however, if any of any
numeric data item is corrupted by the overflow, then
referenced by any one of a dozen instructions.
Is This Answer Correct ? | 7 Yes | 0 No |
Answer / prem
Occur clause is a kind of an array which holds the data of
simalar type in a particular record.
Ex: If we define an occur clause which hold the marks of a
particular student scored in 3 subjects. The code for this
would be as mentioned below
01 Student.
02 Name PIC X(20).
02 MARK OCCURS 3 times PIC 9(03).
So, For a Student "A" marks would be stored in MARK[1], MARK
[2], MARK[3], for "B" MARK[2], MARK[2], MARK[2] likes wise.
In a record format it would be displayed as below
A___________________052060080
B___________________060068070
Total length of the record is 20 + (3*3) = 29
This code will process n number of records no matter what
is the size of occur clause but if the length of the
records is beyond 29 then only the job will abend.
I hope this answers your query.
Is This Answer Correct ? | 5 Yes | 0 No |
Answer / veena
Thanks for the reply ..then will all input file records get
processed or only first 2000 records be processed?
Is This Answer Correct ? | 3 Yes | 0 No |
Answer / sivakumar sekharannair
Yeah vidhya's answer is correct. If the complier option is
set with SSRANGE=Y then the program will fail. Other wise
it will not... the default option is NOSSRANGE...
Is This Answer Correct ? | 2 Yes | 0 No |
Answer / veena
But when i tested with more than 2000 records it not
abending.all input records are process and written to
output file.Thats why i am confused.
Is This Answer Correct ? | 0 Yes | 0 No |
Answer / sadaf rehan
Table OCCURS Clause has nothing to do with the number of
records in the input file..
if you are reading sequentially all the records will get
processed..
Is This Answer Correct ? | 0 Yes | 0 No |
Answer / kingmanish
Its in our hands whether we want the program to abend in
case of data overflow or not.
If we specify SSRANGE = Y the program will abend when the
number to records go beyond 2000.
Otherwise for NO SSRANGE the program will not abend.
Though that data will be lost as we cannot reference it.
Is This Answer Correct ? | 0 Yes | 0 No |
01 a pic x(6) value is abcdef 01 b pic x(3) move a to b wht will be the value in b ?
9(2).99 how many bytes take? Why . consider as a byte?
Difference between file status codes 02 and 22.... since both are for duplicate key detection.
A table has two indexes defined. Which one will be used by the SEARCH?
db2 variable decimal(15,2) what is the equalent size of cobol variable
What is COMP SYNC?
What are differences between COBOL and java ? why we are giving more preference to COBOL ?
How do you define a sort file in JCL that runs the COBOL program?
whats the difference between search and search all?
In an EVALUTE statement is the order of the WHEN clauses significant?
) how do u code after getting data?
whats the disadvantage of search all over search?