VSAM file status code indicates the status of the operation. VSAM files require at least one data record to be initially loaded into the file before the file could be opened for input or update processing. This is because VSAM issues a VERIFY command upon opening a file to reset the end-of-file pointer. If the file has never been loaded, the VERIFY fails because the high used RBA (Relative Byte Address) (HI-USEDRBA) is still zero. Therefore, VSAM files must be initially “loaded” to set the HI-USED-RBA to a value other than zero. This is done by writing a record to the VSAM file in “load” mode and optionally deleting the record to empty the file while leaving the HI-USED-RBA at a non-zero value.
A VSAM file that has never contained a record is treated as unavailable. Attempting to open for input will fail. An empty file can be opened for output only. When you open for output, COBOL will write a dummy record to the file & then delete it out.
VSAM distinguishes between an empty data set (that is, one that has never had a record in it) and a data set with no records (for example, adding a record to a KSDS and then deleting it). The difference is that for each write to a VSAM data set, a pointer is updated to reflect the highest used RBA. If you have never written any data to the data set, this pointer has no value and hence causes VSAM problems when attempting to use it to locate the end of the used data. Any program attempting to open a VSAM data set for input before anything has been written to the data set will have a problem & amend will happen with return code 35 as VSAM is unavailable.
Example
//STEP010 EXEC PGM=IDCAMS //SYSPRINT DD SYSOUT=* //SYSOUT DD SYSOUT=* //SYSIN DD * DELETE XXXXX.TEST.VSAM PURGE CLUSTER DEFINE CLUSTER(NAME(XXXXX.TEST.VSAM) - VOLUME(* *) - UNIQUE - SHAREOPTIONS(3 3) - CYLINDERS(7 7)) - DATA (NAME(XXXXX.TEST.VSAM.DATA) - KEYS (29 0) - RECORDSIZE(35 35) - CISZ(4096)) - INDEX (NAME(XXXXX.TEST.VSAM.INDEX) - NOIMBED NOREPLICATE) /* //STEP020 EXEC PGM=IDCAMS //IN DD DSN=XXXXX.TEST.PS,DISP=SHR //OUT DD DSN=XXXXX.TEST.VSAM,DISP=SHR //SYSOUT DD SYSOUT=* //SYSPRINT DD SYSOUT=* //SYSIN DD * REPRO INFILE(INF) OUTFILE(OUTF) COUNT(1) /*
File Status | Description |
00 | SUCCESSFUL COMPLETION |
02 | DUPLICATE KEY, NON-UNIQUE ALT INDEX |
04 | READ, WRONG LENGTH RECORD |
05 | OPEN, FILE NOT PRESENT |
07 | CLOSE with REEL or NO REWIND executed for non tape dataset. |
10 | END OF FILE |
13 | File Not Found |
14 | Attempted to READ a relative record outside file boundary |
16 | Accessing VSAM file Error |
19 | Accessing VSAM file Error |
20 | INVALID KEY VSAM KSDS OR RRDS |
21 | SEQUENCE ERROR, ON WRITE OR CHANGING KEY ON REWRITE |
22 | DUPLICATE KEY |
23 | RECORD NOT FOUND or FILE NOT FOUND |
24 | Invalid Key – key outside boundary of file. |
28 | Unable to extend the dataset |
30 | Permanent I/O Error |
34 | Permanent I/O Error – Record outside file boundary |
35 | OPEN, FILE NOT PRESENT |
37 | Open file error due to opening mode |
38 | Tried to OPEN a LOCKed file |
39 | LOGIC ERROR |
41 | OPENING A FILE THAT IS ALREADY OPENED |
42 | CLOSING A FILE WITHOUT OPEN |
43 | DELETE OR REWRITE & NO GOOD READ FIRST |
44 | Tried to REWRITE a record of a different length |
46 | SEQUENTIAL READ WITHOUT POSITIONING |
47 | READING FILE NOT OPEN AS INPUT/IO/EXTEND |
48 | WRITE WITHOUT OPEN IN IO MODE |
49 | DELETE OR REWRITE WITHOUT OPEN IN IO MODE |
90 | Unsuccessful OPEN, READ, WRITE or CLOSE operation |
91 | Password or authorization failed |
92 | LOGIC ERROR / OPENING A OPEN FILE / READING OUTPUT FILE / WRITING INTO A INPUT FILE / DEL or REW BUT NO PRIOR READ |
93 | OPENING A FILE THAT IS ALREADY OPENED |
94 | SEQUENTIAL READ AFTER END OF FILE / NO CURRENT REC POINTER FOR SEQ |
95 | File Information invalid or incomplete |
96 | MISSING DD STATEMENT IN JCL |
97 | OPEN OK, FILE INTEGRITY VERIFIED |
98 | The file is Locked – OPEN failed |
99 | Record Locked – record access failed |
100 | Improper loading |
160 | Input file might be empty |
168 | The device type is not supported |
VSAM return code 00 – SUCCESSFUL COMPLETION
Root Cause:
Fix:
VSAM return code 04 – READ, WRONG LENGTH RECORD
Root Cause: The logical error in the program
Fix: The Logic of the COBOL Program itself is wrong so you need to correct the logic of the program.
VSAM return code 13 – File Not Found
Root Cause: File Not Found
Fix: Provide the correct details of the file name. Check if the path of your VSAM file is correct.
VSAM return code 16 – Accessing VSAM file Error
Root Cause: It depends on the type of file, the program used to access the VSAM file and is mostly related to accessing
Fix: Fix will be based on the way you are accessing the file from a program. Are you trying to update a file for which you do not have permission?
VSAM return code 19 – Accessing VSAM file Error
Root Cause: In case you are accessing the VSAM file in CICS and you did not provide a proper entry of the file
Fix: Check if the PCT entry of the file is proper.
VSAM return code 20 – INVALID KEY VSAM KSDS OR RRDS
Root Cause: In the case of KSDS or RRDS, the key is an INVALID KEY
Fix: Correct the KEY. Check the position, definition, etc and correct it.
VSAM return code 22 – DUPLICATE KEY
Root Cause: Duplicate key defined for Indexed or relative Files. Duplicate alternate key but the alternate key is defined as unique.
Fix: Remove the duplicate entry of the key.
VSAM return code 23 – RECORD NOT FOUND or FILE NOT FOUND
Root Cause: The record is not found when you are trying to access using a key. File not found.
Fix: Check if the record is correct or the path to access the file is given correctly.
VSAM return code 24 – Invalid Key – key outside the boundary of file.
Root Cause: Trying to write beyond the boundary in case of Relative and indexed files using the key. The size of the Relative Record number is larger.
Fix: Do not write beyond the boundary or change the boundary.
VSAM return code 28 – Unable to extend the dataset
Root Cause:
Fix: Check with your storage group or try to give less value to your secondary allocation.
VSAM return code 35 – OPEN, FILE NOT PRESENT
Root Cause: You are trying to open a file that is not present.
Fix:
VSAM return code 37 – Open file error due to opening mode
Root Cause: You are trying to open a file in a particular mode that is not allowed for that file.
Fix: Check the file opening modes available for the file and fix it.
VSAM return code 39 – LOGIC ERROR
Root Cause:
Fix: Check the file attribute in the actual file, the file attributes defined in the FD section of the program, the record length in your DCB Parameter and the record mode, etc.
VSAM return code 41 – OPENING A FILE THAT IS ALREADY OPENED
Root Cause: You are trying to open a file in a particular mode that is not allowed for that file.
Fix: Check the file opening modes available for the file and fix it.
VSAM return code 42 – CLOSING A FILE WITHOUT OPEN.
Root Cause: When the file is already closed and you try to do a CLOSE operation once again on the file which is already closed.
Fix: Change the program to make sure that you do not give a CLOSE file on the file which is already closed.
VSAM return code 46 – SEQUENTIAL READ WITHOUT POSITIONING
Root Cause: If you try to sequentially read a file even when the end of the record is reached.
Fix: Once the End of the File is reached, do not read the file.
VSAM return code 47 – READING FILE NOT OPEN AS INPUT/IO/EXTEND
Root Cause: File not opened in INPUT or I-O mode.
Fix: Open the file in INPUT or I-O mode.
VSAM return code 90 – Unsuccessful OPEN, READ, WRITE or CLOSE operation
Root Cause:
Fix:
VSAM return code 91 – Password or authorization failed
Root Cause: Password Failure. Authorization failure.
Fix: Check the password which is given for VSAM file or whether you are authorized to access the file or not?
VSAM return code 92 – LOGIC ERROR / OPENING A OPEN FILE / READING OUTPUT FILE / WRITING INTO A INPUT FILE / DEL or REW BUT NO PRIOR READ
Root Cause:
Fix:
VSAM return code 93 – OPENING A FILE THAT IS ALREADY OPENED
Root Cause:
Fix: Check with your storage group.
VSAM return code 96 – MISSING DD STATEMENT IN JCL
Root Cause: Missing DD statement for the VSAM or QSAM file.
Fix: Code the missing DD statement in the JCL
VSAM return code 97 – OPEN OK, FILE INTEGRITY VERIFIED
Root Cause: OPEN file successful and the file integrity verified. This might happen when a previous Job did not close the file so VSAM has to verify the integrity of the file.
Fix: Check the file opening modes available for the file and fix it.
VSAM return code 100 – Improper loading
Root Cause:
Fix: Before building the alternate index(AIX) and path, you need to load the cluster.
VSAM return code 160 – input file might be empty
Root Cause: The input file might be empty when you try to open it.
Fix: Check with your storage group.
VSAM return code 168 – The device type is not supported
Root Cause: The device type is not supported.
Fix: Check with your admin.
1. During the processing of a VSAM file, some system error occurs and it is subsequently unusable how to fix this issue?
Answer: Run VERIFY
2. How do you fix the problem associated with VSAM file status out of space condition?
Answer:
Effective User interviews play a crucial role in Scrum methodology, helping Product Owners and Scrum…
Product Owners should be well-versed in various user research tools and techniques to effectively understand…
Effective Product Owner plays a crucial role in Agile development, acting as the bridge between…
A well-maintained product backlog is crucial for successful product development. It serves as a single…
Incremental value to the customer refers to the gradual delivery of small, functional parts of…
A Product Market refers to the group of potential customers who might be interested in…