You are on page 1of 9

VSAM Tutorial How to create a ESDS and RRDS Cluster ~ MAINFRAMES TUTORIAL, JCL TUTORIAL, VSAM TUTORIAL, COBOL

L TUTORIAL, DB2 TUTORIAL, CICS

Bulletin Board
Whats new at MAINFRAMES 360

(Updates)...

- Working on Cosmetic enhancements to navigation menu on the Sidebar, so that it will


dynamically expand..
- Resolved some Display issues and filling in the gaps(missing tutorials like VSAM)
- Posting several Video tutorials

Mainframes360 Search
Search
powered by

Quick Links

http://www.mainframes360.com/2009/07/vsam-tutorial-how-to-create-esds-and.html (1 of 9)12/23/2009 4:49:46 AM

VSAM Tutorial How to create a ESDS and RRDS Cluster ~ MAINFRAMES TUTORIAL, JCL TUTORIAL, VSAM TUTORIAL, COBOL TUTORIAL, DB2 TUTORIAL, CICS

Jump to :
<== Previous Tutorial

-------

Monday, July 27, 2009

VSAM Tutorial How to create a ESDS and RRDS Cluster


Q. How do you create an ESDS Object using JCL/Batch JOB?
An ESDS Cluster is a VSAM Dataset, which is similar to a sequential file. An
ESDS Dataset has no Index Structure. Now, you might wonder, how to access the
records of an ESDS Cluster. Well, to access a record in an ESDS Cluster, you
need to know the exact address/physical location, where record lies on the Disk
Volume. Its like saying, if you had a 1000 page book, and you wanted to access
the line having keyword laugh, you must know beforehand on which page no
(address) laugh is.
Thus, Records in ESDS Cluster are accessed by their Physical Address. This
address is called Relative Byte Address(RBA). ESDS works just like a stack/pile
of books. If you add records, they always get added to the top of the pile/
stack, i.e. the records get appended. Since the pile is too heavy, it is not
possible to insert records in between.
Here, Ive shown how to create an empty ESDS Cluster using IDCAMS, DEFINE
CLUSTER Control statement.
----+----1----+----2----+----3----+----4----+----5----+----6----+----7-//MYJOB004 JOB A123,QUASAR,NOTIFY=&SYSUID
//STEP01 EXEC PGM=IDCAMS
//SYSPRINT DD DSN=CAA0176.DEMO.JOBLOG,DISP=(OLD,KEEP,KEEP)
//SYSIN DD
*
DEFINE CLUSTER(
NAME(CAA0176.DEMO.ESDS)
TRACKS(1 1)
RECORDSIZE(80 80)
NONINDEXED
)
DATA(
NAME(CAA0176.DEMO.ESDS.DATA)
)
/*
//
In the above example, Ive created a new ESDS Cluster with the name CAA0176.
DEMO.ESDS. This ESDS Cluster will be allocated space(extents) in terms of 1
Primary Track and 1 Secondary Track. All records in this ESDS Cluster will be
of length 80 bytes. Moreover, since an ESDS Cluster does not have any key, we
dont write KEYS keyword. Also, ESDS Cluster is specified using the option
NONINDEXED.
http://www.mainframes360.com/2009/07/vsam-tutorial-how-to-create-esds-and.html (2 of 9)12/23/2009 4:49:46 AM

Next Tutorial ==>

VSAM Tutorial How to create a ESDS and RRDS Cluster ~ MAINFRAMES TUTORIAL, JCL TUTORIAL, VSAM TUTORIAL, COBOL TUTORIAL, DB2 TUTORIAL, CICS

Since, it has on DATA Component, only the DATA Sub-parameter has been coded.
The ESDS Data component will have the name CAA0176.DEMO.ESDS.DATA.
Q. How do you create an RRDS Object using a Batch JOB/JCL?
In a Relative Record Dataset, you must recall that each record is identified by
a Relative Record Number(RRN), which is nothing but the sequence number
relative to the first record.
Note : As opposed to KSDS, ESDS and RRDS support only fixed length records.
In RRDS, space is divided into fixed length slots. A slot can be either
completely vacant(does not contain a record) or completely full(contains a
record). Thus, you can add new records to empty slots, and delete existing
records from slots which are filled.
Lets see a simple JCL to create an RRDS Cluster :
----+----1----+----2----+----3----+----4----+----5----+----6----+----7-//MYJOB004 JOB A123,QUASAR,NOTIFY=&SYSUID
//STEP01 EXEC PGM=IDCAMS
//SYSPRINT DD DSN=CAA0176.DEMO.JOBLOG,DISP=(OLD,KEEP,KEEP)
//SYSIN DD
*
DEFINE CLUSTER(
NAME(CAA0176.DEMO.RRDS)
TRACKS(1 1)
RECORDSIZE(80 80)
NUMBERED
REUSE
)
DATA(
NAME(CAA0176.DEMO.RRDS.DATA)
)
/*
//
RRDS is created on the same lines, like how we created an ESDS. The only
difference being that since RRDS records are accessed by RRN(Sequence Number),
we must code NUMBERED inside the DEFINE CLUSTER AMS Command.
Technorati Tags: KSDS Cluster,ESDS,RRDS,Entry Sequenced Datset,Key-sequenced Dataset,Relative Record Dataset,Slots,Fixed Length,Relative Record Number,RRN,
Relative Byte Address,RBA,DEFINE CLUSTER,AMS,DATA,INDEX,KEYS,RECORDSIZE,TRACKS,NAME,NUMBERED,INDEXED Sequential,NONINDEXED,REUSE,CISZ,Mainframes,
IBM Mainframes 360,Mainframes 360,Quasar Chunawalla,VSAM,VSAM Tutorial,How to create ESDS and RRDS,ESDS Basics,RRDS Basics
Posted by Quasar at Monday, July 27, 2009
Reactions:

0 comments:
http://www.mainframes360.com/2009/07/vsam-tutorial-how-to-create-esds-and.html (3 of 9)12/23/2009 4:49:46 AM

VSAM Tutorial How to create a ESDS and RRDS Cluster ~ MAINFRAMES TUTORIAL, JCL TUTORIAL, VSAM TUTORIAL, COBOL TUTORIAL, DB2 TUTORIAL, CICS

Post a Comment

Links to this post


Create a Link

Newer Post Older Post Home


Subscribe to: Post Comments (Atom)

Quick Links
<== Previous Tutorial

Jump to :
-------

Note :
Copyright Quasar Chunawalla, Tata Consultancy Services,2009.
Note : The copyrights of all the material, text and pictures posted in this website
belong to the author. Any instance of lifting the material from this website, shall
be considered as an act of plagiarism. For any clarifications, please mail at quasar.
chunawala@tcs.com

http://www.mainframes360.com/2009/07/vsam-tutorial-how-to-create-esds-and.html (4 of 9)12/23/2009 4:49:46 AM

Next Tutorial ==>

VSAM Tutorial How to create a ESDS and RRDS Cluster ~ MAINFRAMES TUTORIAL, JCL TUTORIAL, VSAM TUTORIAL, COBOL TUTORIAL, DB2 TUTORIAL, CICS

Globe-trotting
Some Excerpts from Mainframes360
Q. What are the two broad types of Applications/Systems?
All application/systems are of 2 types
(i) Online Systems(Transaction Processing Systems)
(ii)Batch Processing Systems. Read more ...

Q. What is the DATA DIVSION? What are the different sections in the DATA DIVISION?
DATA DIVISION is used to describe the Input Output Storage areas and temporary storage areas. In other words, itll describe the
structure of the data being stored in Input Output Files, as well as in any temporary storage. Read more ...

Q. What are data-types? What are the basic data-types in COBOL?


Data-type is used to announce/declare to the MVS O/S, about the type of data youre gonna store in a Storage Location, so that it
can estimate the storage space to be allocated and reserved for you data excusively. Read more ...

Q. What are group and Elementary Data Items?


In COBOL, one or more elementary data-items can be grouped together. For example, we can group EMP-NAME, EMP-SALARY and EMP-JDATE
as EMPLOYEE-RECORD. In COBOL, we say that a group item is a data item, which has several low-level(elementary) data-items. Read
http://www.mainframes360.com/2009/07/vsam-tutorial-how-to-create-esds-and.html (5 of 9)12/23/2009 4:49:46 AM

VSAM Tutorial How to create a ESDS and RRDS Cluster ~ MAINFRAMES TUTORIAL, JCL TUTORIAL, VSAM TUTORIAL, COBOL TUTORIAL, DB2 TUTORIAL, CICS

more ...

Q. Can you elaborate on how to write the File Descriptor FD Paragraph?


As mentioned before, we must describe the input file record format and output file record format in the File Descriptor FD
paragraph under the FILE SECTION. Remember, that FD paragraph is always coded in AREA A. Read more ...

Q. What is JOB Log? Why do we need a JOB Log? What purpose does it serve?
When you submit a Batch JOB/JCL to the MVS System, the MVS executes the Job Stream, makes the necessary resources available to the
the EXEC PGM (Program), and finally tells you the result of the Job. Read more ...

Q. In the previous tutorial, youve stated what is compiling, linking and running.. Can you show me a Compiler and
Linking JCL/Job Stream that does this?
Sure, as you know, the Compiler takes a SYSIN DD Input Dataset, which is the Source COBOL Program. The COBOL Compiler IGYWC(or
IGYCRCTL) produces SYSOUT DD Dataset containing the JOB Log and Status messages, and more importantly, SYSLIN DD which is Object
Module and Input for the Linker. Read more ...

Q. Show me a simple JCL/JOB Stream to run my COBOL Program(LOAD MODULE).


On Windows, to run a program, we simply click on the Executable File. In the same way, to run our COBOL Program on Mainframes, we
are going to use the LOAD MODULE(Executable). To run a program on the MVS, you write JCL. You specify the name of the Program(LOAD
MODULE) Read more ...

Q. What is the ENVIRONMENT DIVISION? What purpose does it serve in the COBOL Program?
The ENVIRONMENT DIVISION provides information about the computer equipment/configuration upon which the COBOL program will run. It
also gives the name of the input and output files used in the program. It assigns the file-names to ddnames(DD Statements in the
Run JCL). Read more ...

Q. What is a Mainframe Computer?


A Mainframe computer is used by large organisations for processing huge volumes of data e.g. census, consumer statistics, ERP and
financial transaction processing. Read more ...

Q. How did IBM Mainframe machines evolve?


Well, IBM first launched the System/360, then System/370, System 370/XA, Enterprise System Architecture(ESA)/370, System 390 and
the latest machines in the Mainframe series is zSeries(pronounce Zee). Read more ...

Q. What does a Mainframe Computer look like? How do you operate it?
Lets just try to see whats life like, if you are Mainframe machines operator. A Desktop computer can fit into a trolley or a
cabinet. A Mainframe Machine is generally big monster-size, would fill up a room. On a Desktop PC, you would sit near the physical
computer and operate it using the keyboard and the mouse, and see the result on the monitor. Read more ...

Q. Hey, Windows is the most popular Operating System on a Desktop-PC. On the same lines, the popular Mainframes
Operating System is MVS...
http://www.mainframes360.com/2009/07/vsam-tutorial-how-to-create-esds-and.html (6 of 9)12/23/2009 4:49:46 AM

VSAM Tutorial How to create a ESDS and RRDS Cluster ~ MAINFRAMES TUTORIAL, JCL TUTORIAL, VSAM TUTORIAL, COBOL TUTORIAL, DB2 TUTORIAL, CICS

Bulls-eye! In fact, MVS is said to be the Operating System that makes the world move. Read more ...

Q. What about Super-computers? Are mainframes faster than super-computers?


Dont equate the word Mainframes to Speed. Mainframes have tremendous processing power or computational power, but of a different
kind. Think of task, where we have 1,00,000 records of Input data, and we want to perform 3 calculations on each record, and then
put the Output Records in a separate file. Read more ...

Q. Whats that name again.. Multiple Virtual Storage? What crap?


Virtual Storage is a simple idea. Virtual storage simulates a large amount of main storage(Primary or main memory) by treating the
auxiliary storage as an extension of the real storage. Thus, a program gets the feel, Wow, I have an infinite amount of computer
memory at my disposal. Read more ...

Q. What is a Batch Job?


If you are a college student, you would have probably written a computer application in C, and executed it on your desktop PC. You
run the program interactively, you type in some input data, wait for the response(output), and then you type some more input, and
this cycle continues. Such programs or systems are called as Online Systems or Transaction Processing Systems. Read more ...

Q. Look, on Windows PC, you interact with the computer using the Windows GUI the Desktop Icons, the Menus,
Buttons etc. How do you interact with an MVS Mainframe System?
MVS offers several ways to interact with it. The 3 main ways of interacting with MVS are TSO, ISPF and CICS. Read more ...

Q. What does COBOL stand for? What are the application areas where COBOL Programs written?
COBOL stands for Common Business Oriented Language. COBOL Programs are used for commercial data processing. COBOL is an Englishlike language. Writing a COBOL program is just like writing a passage in English. Read more ...

Q. You said COBOL Programming language bears resemblance with English. Do COBOL Programs have paragraphs like in
English?
A COBOL Program consists of 4 main divisions : IDENTIFICATION DIVISION, ENVIRONMENT DIVISION, DATA DIVISION and PROCEDURE DIVISION.
IDENTIFICATION DIVISION is used to identify the COBOL Program to the system. It tells the... Read more ...

Q. Show me the basic skeleton of a COBOL Program then..


The basic skeleton of a COBOL Program is as follows : IDENTIFICATION DIVISION. ENVIRONMENT DIVISION. Read more ...

Q. Paragraphs in the English language are indented. Do you have indentation/alignment rules in COBOL?
Just like paragraphs in English, COBOL Divisions and Paragraphs must follow strict alignment rules. The way we indent paragraphs in
English, you must indent different Divisions, sections and paragraphs in a COBOL Program. When you write .. Read more ...

Q. What is the IDENTIFICATION DIVISION used for?


The IDENTIFICATION DIVISION is used to identify the COBOL Program to the system. It has the following paragraphs :
PROGRAM-ID.
AUTHOR.
http://www.mainframes360.com/2009/07/vsam-tutorial-how-to-create-esds-and.html (7 of 9)12/23/2009 4:49:46 AM

VSAM Tutorial How to create a ESDS and RRDS Cluster ~ MAINFRAMES TUTORIAL, JCL TUTORIAL, VSAM TUTORIAL, COBOL TUTORIAL, DB2 TUTORIAL, CICS

Read more ...

Q. What does the PROCEDURE DIVISION look like? Whats the format/syntax. Can you elaborate..
The PROCEDURE DIVISION indicates the entry-point or starting point of the COBOL Program. This is where the computer system begins
to run(execute the COBOL instructions). Hence, all your instructions/programming logic must be written inside this PROCEDURE
DIVISION. Read more ...

Q. How do you compile a COBOL Program? What is meant by Linking a COBOL Program? Finally, how do you run the
Program on a Mainframe System?
Compiling a COBOL Program : COBOL is a high-level language. The Mainframe Computer System only understands binary Machine Language
0 and 1. Thus, your COBOL Program has to be translated from COBOL Language to Binary Machine Language. So, you give the Program in
COBOL Language as Input to the Translator(Compiler), and you get the Output Program in Binary Machine Language. Read more ...

Q. Could you throw some light on the WORKING-STORAGE SECTION of a COBOL Program?
The WORKING-STORAGE SECTION is used to declare any fields or records that are not going to be used in input files, or output files,
but they are used to store the intermediate results of processing in a temporary storage area. Read more ...

Navigation
Navigation

- Main Page
- Questions Archive
- Articles and Writing
Tutorials

+
+
+
+
-

JCL Tutorials(12)
IBM Utilities Tutorials(08)
COBOL Tutorials(08)
DB2 Tutorials
VSAM Tutorials
CICS Tutorials
REXX Tutorials
ISPF Panel Programming

FAQs
- How do I learn Mainframes?
- Coaching and Institutes
- Mail me
- JOB Prospects
- Idea behind Mainframes 360

http://www.mainframes360.com/2009/07/vsam-tutorial-how-to-create-esds-and.html (8 of 9)12/23/2009 4:49:46 AM

VSAM Tutorial How to create a ESDS and RRDS Cluster ~ MAINFRAMES TUTORIAL, JCL TUTORIAL, VSAM TUTORIAL, COBOL TUTORIAL, DB2 TUTORIAL, CICS

Follow the Buzz..

Technorati
Add this blog to your favourites..

Subscribe To
Posts
Comments

About Me
Quasar Chunawalla
Chennai, Tamil Nadu, India

Working at Tata Consultancy Services, Chennai


View my complete profile

http://www.mainframes360.com/2009/07/vsam-tutorial-how-to-create-esds-and.html (9 of 9)12/23/2009 4:49:46 AM

You might also like