Key Sequenced Data Set Identify and Document |
The SimoTime Home Page |
This document will describe how to create a list of the Key Sequenced Data Sets (VSAM, KSDS's) that are used by an application or group of applications. Once a list is created it will be used to programmatically create the entries in the Micro Focus catalog.
For this example we will use Microsoft Excel to create and maintain the list of VSAM, KSDS's and their properties.
| ||||||||
Glossary of Terms or Acronyms used in this Document |
We have made a significant effort to ensure the documents and software technologies are correct and accurate. We reserve the right to make changes without notice at any time. The function delivered in this version is based upon the enhancement requests from a specific group of users. The intent is to provide changes as the need arises and in a timeframe that is dependent upon the availability of resources.
Copyright © 1987-2025
SimoTime Technologies and Services
All Rights Reserved
The following is the column structure for an Excel spreadsheet to be used as a starting point to populate the catalog.
| ||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Format of an Excel Spread Sheet |
The following COBOL Copy File (LONAPFFL.cpy) shows the record layout for the Record Sequential File with a Fixed Field Format that is used for a list of names for the VSAM, KSDS's that are used by the application.
***************************************************************** * LONAPFFL.CPY - a COBOL Copy File * * Record Layout for the File Properties Repository * * The record stucture is a fixed length of 1,024 characters * * Copyright (C) 1987-2019 SimoTime Technologies * * All Rights Reserved * * Provided by SimoTime Technologies * * Our e-mail address is: helpdesk@simotime.com * * Also, visit our Web Site at http://www.simotime.com * ***************************************************************** * The information that is imported into this format originates * from an Excel spreadsheet. The spreadsheet is saved to an * ASCII/Text File with a Comma-Separated-Values (or CSV) record * structure. * * LONAP is an acronym for a List Of Names And Properties. * CSV is an acronym for Comma-Separated-Values. * FFL is an acronym for Fixed-Field-Length. * * A conversion program is used to convert the CSV File to a * Record Sequential File with the following Fixed Field format. * * The fields are all fixed length. * Numeric fields are right-adjusted with leading zeroes. * Alpha-numeric fields are left adjusted with trailing spaces. * * Positions 73-80 of the following statements are used to * identify the original columns used in the Excel spreadsheet. * 01 LONAPFFL-REC. Excel 05 LONAPFFL-LEVEL-CHR. 10 LONAPFFL-LEVEL-NBR PIC 9(2). col-A 05 LONAPFFL-FILE-INFO. 10 LONAPFFL-DSN PIC X(54). col-B 10 LONAPFFL-DD-NAME PIC X(17). col-C 10 LONAPFFL-DSORG PIC X(4). col-D 10 LONAPFFL-RECFM PIC X(4). col-E 10 LONAPFFL-LRECL-MIN PIC 9(5). col-F 10 LONAPFFL-LRECL-MAX PIC 9(5). col-G 10 LONAPFFL-KEYPOS PIC 9(5). col-H 10 LONAPFFL-KEYLEN PIC 9(5). col-I 10 LONAPFFL-VSAM-DAT PIC X(58). col-J 10 LONAPFFL-VSAM-IDX PIC X(58). col-K 05 LONAPFFL-JOB-EXEC. 10 LONAPFFL-JCL-OVR1 PIC X(8). col-L 10 LONAPFFL-JCL-USR1 PIC X(8). col-M 10 LONAPFFL-JCL-USR2 PIC X(8). col-N 05 LONAP-EXTENDED-GROUP. 10 LONAPFFL-EXTENDED-S1 PIC X(4). col-O 10 LONAPFFL-EXTENDED-S2 PIC X(4). col-P 10 LONAPFFL-EXTENDED-M1 PIC X(16). col-Q 10 LONAPFFL-EXTENDED-M2 PIC X(16). col-R 10 LONAPFFL-EXTENDED-M3 PIC X(16). col-S 10 LONAPFFL-EXTENDED-M4 PIC X(16). col-T 10 LONAPFFL-EXTENDED-X1 PIC X(256). col-U 10 LONAPFFL-EXTENDED-X2 PIC X(256). col-V 05 FILLER PIC X(199). * *** LONAPFFL - End-of-Copy File - - - - - - - - - - - LONAPFFL * ***************************************************************** *
From within Excel save the KSDS List of Names and Properties to a CSV file. Execute the command (CATKSDE1.CMD) to convert the Line Sequential file with comma separated values to a record Sequential file with fixed field lengths.
The following shows the process flow of the CATKSDE1.CMD member.
CMD, Convert/Catalog KSDS List FileThe KSDS List File is a list of names and properties for the VSAM, KSDS's that need a catalog entry to be created. The following member (CATKSDE1.cmd) is the command to convert the KSD List File from a Line Sequential file with a record format of Comma-Separated-Values (CSV) to a Record Sequential file with a record format of Fixed-Field-Lengths (FFL). As the last step the command will submit a job to the Micro Focus Server to make a catalog entry for the KSDS List File. @echo OFF rem * ******************************************************************* rem * CATKSDE1.CMD - a Windows Command File * rem * This program is provided by SimoTime Technologies * rem * (C) Copyright 1987-2019 All Rights Reserved * rem * Web Site URL: http://www.simotime.com * rem * e-mail: helpdesk@simotime.com * rem * ******************************************************************* rem * rem * Text - Convert LONAPCSV to LONAPFFL for a VSAM, KSDS. rem * Author - SimoTime Technologies rem * Date - January 24, 1996 rem * rem * LONAP - an acronym for a List Of Names And Properties. rem * CSV - an acronym for Comma-Separated-Values. rem * FFL - an acronym for Fixed-Field-Length. rem * rem * The job will convert an LSEQ file of variable length records rem * to an RSEQ file of 1,024-byte fixed length records. The text rem * string in the individual records will be converted from a rem * Comma-Separated-Values (CSV) text string to a record structure rem * with a Fixed-Field-Length (FFL) format. rem * rem * ************ rem * * CATKSDE1 * rem * ********cmd* rem * * rem * ************ ************ rem * * CATKSDJ9 *-----* LONAPFFL * DISP=DELETE rem * ********jcl* *******rseq* rem * * rem * ************ ************ ************ rem * * LONAPCSV *-----* LONAPTIO *-----* LONAPFFL * CSV to FFL rem * *******lcsv* ********cbl* *******rseq* rem * * rem * ************ ************ rem * * CATKSDJ1 *-----* LONAPFFL * DISP=CATLG rem * ********jcl* *******rseq* rem * * rem * ************ rem * * EOJ * rem * ************ rem * rem * rem * ******************************************************************* rem * Step 1 of 4, Preparation, Set the Environment... rem * set CmdName=CATKSDE1 set SERVERNAME=SIMOBATA call ..\..\Env1BASE %CmdName% if "%SYSLOG%" == "" set syslog=c:\SimoLIBR\LOGS\SimoTime.LOG rem * call SimoNOTE "*******************************************************%CmdName%" call SimoNOTE "Starting CmdName %CmdName%" call SimoNOTE "StepInfo Map DD File Names to DSN File Names" set LONAPCSV=%BaseLib1%\DATA\XLSS\LONAPKSD.CSV set LONAPFFL=%BASECAT%\APPL\SIMOTIME.UTIL.KSDLIST1.DAT rem * rem * ******************************************************************* rem * Step 2 of 4, Delete a possible file from a previous execution. rem * Note: This step requires the SIMOBATA Server to be started. rem * call SimoNOTE "StepInfo Delete a possible file from a previous execution" call SYS1SCHEDULE %JESSERVERNAME% CATKSDJ9 if not "%ERRORLEVEL%" == "0" set JobStatus=0010 if not %JobStatus% == 0000 goto :EojNok rem * rem * ******************************************************************* rem * Step 3 of 3, Convert the Line Sequential File of CSV record format rem * to a Record Sequential file with Fixed-Field record format. rem * Note: This step will do a File Format conversion (i.e. Line rem * Sequential to Record Sequential) and a record content conversion rem * (i.e. CSV to Fixed-Field). rem * call SimoNOTE "StepInfo Execute the File Format and Record Content Conversion" run LONAPTIO if not "%ERRORLEVEL%" == "0" set JobStatus=0020 if not %JobStatus% == 0000 goto :EojNok call SimoNOTE "DataTake %LONAPCSV%" call SimoNOTE "DataMake %LONAPFFL%" rem * rem * ******************************************************************* rem * Step 3 of 3, Define a Catalog entry for SIMOTIME.UTIL.KSDLIST1 rem * in the Catalog for the SIMOBATA JES Server. rem * Note: This step requires the SIMOBATA Server to be started. rem * call SimoNOTE "StepInfo Define a Catalog entry for SIMOTIME.UTIL.KSDLIST1" call SYS1SCHEDULE %JESSERVERNAME% CATKSDJ1 if not "%ERRORLEVEL%" == "0" set JobStatus=0030 if not %JobStatus% == 0000 goto :EojNok rem * if exist %LONAPFFL% goto :EojAok set JobStatus=0020 goto :EojNok :EojAok call SimoNOTE "Finished JobName %CmdName%, Job Status is %JobStatus%" goto :End :EojNok call SimoNOTE "ABENDING JobName %CmdName%, Job Status is %JobStatus%" :End if not "%1" == "NOPAUSE" PAUSE JCL MembersTwo JCL Members are supplied with this part of the process to make catalog entries for VSAM, KSDS's. The following sections describe the JCL Members and their function. Delete a Previously Created KSDS ListIf a KSDS LIST File was created in a previous execution then it must be deleted before we can add a new KSDS List file and the associated catalog entry. This job (CATKSDJ9.jcl) will delete the KSDS List file. //CATKSDJ9 JOB SIMOTIME,CLASS=1,MSGCLASS=0,NOTIFY=CSIP1 //* ******************************************************************* //* This JCL Member is provided by SimoTime Technologies * //* (C) Copyright 1987-2016 All Rights Reserved * //* Web Site URL: http://www.simotime.com * //* e-mail: helpdesk@simotime.com * //* ******************************************************************* //* //* Text - Delete a previously created KSDLIST file. //* Author - SimoTime Technologies //* Date - January 24, 1996 //* //* //* ******************************************************************* //* Step 1 of 1, Delete a previously created file. //* //TOSSFILE EXEC PGM=IEFBR14 //KSDLIST1 DD DSN=SIMOTIME.UTIL.KSDLIST1,DISP=(MOD,DELETE,DELETE), // STORCLAS=MFI, // SPACE=(TRK,5), // DCB=(RECFM=FB,LRECL=1024,DSORG=PS) //* Create a New Catalog EntryThis job (CATKSDJ1.jcl) will add a catalog entry for the KSDS List File. The job executes theIEFBR14 program and uses a DD statement to create the catalog entry. //CATKSDJ1 JOB SIMOTIME,CLASS=1,MSGCLASS=0,NOTIFY=CSIP1 //* ******************************************************************* //* This JCL Member is provided by SimoTime Technologies * //* (C) Copyright 1987-2016 All Rights Reserved * //* Web Site URL: http://www.simotime.com * //* e-mail: helpdesk@simotime.com * //* ******************************************************************* //* //* Text - Create a catalog entry for the KSDLIST file. //* Author - SimoTime Technologies //* Date - January 24, 1996 //* //* //* ******************************************************************* //* Step 1 of 1, Create a Catalog Entry for the KSDLIST. This is a file //* with records of 1,024 bytes and Fixed Field Length. //* //CATENTRY EXEC PGM=IEFBR14 //KSDLIST1 DD DSN=SIMOTIME.UTIL.KSDLIST1,DISP=(NEW,CATLG,CATLG), // STORCLAS=MFI, // SPACE=(TRK,5), // DCB=(RECFM=FB,LRECL=1024,DSORG=PS) //* SummaryThe purpose of this document is to focus on the task of populating a catalog with the entries for Key Sequenced Data Sets or VSAM, KSDS's. The document may be used as a tutorial for new programmers or as a quick reference for experienced programmers. In the world of programming there are many ways to solve a problem. This documentation and software were developed and tested on systems that are configured for a SIMOTIME environment based on the hardware, operating systems, user requirements and security requirements. Therefore, adjustments may be needed to execute the jobs and programs when transferred to a system of a different architecture or configuration. SIMOTIME Services has experience in moving or sharing data or application processing across a variety of systems. For additional information about SIMOTIME Services or Technologies please contact us using the information in the Contact or Feedback section of this document.
Permission to use, copy, modify and distribute this software, documentation or training material for any purpose requires a fee to be paid to SimoTime Technologies. Once the fee is received by SimoTime the latest version of the software, documentation or training material will be delivered and a license will be granted for use within an enterprise, provided the SimoTime copyright notice appear on all copies of the software. The SimoTime name or Logo may not be used in any advertising or publicity pertaining to the use of the software without the written permission of SimoTime Technologies. SimoTime Technologies makes no warranty or representations about the suitability of the software, documentation or learning material for any purpose. It is provided "AS IS" without any expressed or implied warranty, including the implied warranties of merchantability, fitness for a particular purpose and non-infringement. SimoTime Technologies shall not be liable for any direct, indirect, special or consequential damages resulting from the loss of use, data or projects, whether in an action of contract or tort, arising out of or in connection with the use or performance of this software, documentation or training material. Downloads and LinksThis section includes links to documents with additional information that are beyond the scope and purpose of this document. The first group of documents may be available from a local system or via an internet connection, the second group of documents will require an internet connection. Note: A SimoTime License is required for the items to be made available on a local system or server. Current Server or Internet AccessThe following links may be to the current server or to the Internet. Note: The latest versions of the SimoTime Documents and Program Suites are available on the Internet and may be accessed using the icon. If a user has a SimoTime Enterprise License the Documents and Program Suites may be available on a local server and accessed using the icon. Explore the JCL Connection for more examples of JCL functionality with programming techniques and sample code. Explore the COBOL Connection for more examples of COBOL programming techniques and sample code. Explore the non-Relational Data Connection for more examples of accessing methodologies and coding techniques for Data Files and VSAM Data Sets. Explore An Enterprise System Model that describes and demonstrates how Applications that were running on a Mainframe System and non-relational data that was located on the Mainframe System were copied and deployed in a Microsoft Windows environment with Micro Focus Enterprise Server. Explore The ASCII and EBCDIC Translation Tables. These tables are provided for individuals that need to better understand the bit structures and differences of the encoding formats. Explore The File Status Return Codes that are used to interpret the results of accessing VSAM data sets and/or QSAM files. Internet Access RequiredThe following links will require an internet connect. A good place to start is The SimoTime Home Page for access to white papers, program examples and product information. This link requires an Internet Connection Explore The Micro Focus Web Site for more information about products (including Micro Focus COBOL) and services available from Micro Focus. This link requires an Internet Connection. Glossary of TermsExplore the Glossary of Terms for a list of terms and definitions used in this suite of documents and white papers. Contact or FeedbackThis document was created and is maintained by SimoTime Technologies. If you have any questions, suggestions, comments or feedback please use the following contact information.
We appreciate hearing from you. Company OverviewSimoTime Technologies was founded in 1987 and is a privately owned company. We specialize in the creation and deployment of business applications using new or existing technologies and services. We have a team of individuals that understand the broad range of technologies being used in today's environments. Our customers include small businesses using Internet technologies to corporations using very large mainframe systems. Quite often, to reach larger markets or provide a higher level of service to existing customers it requires the newer Internet technologies to work in a complementary manner with existing corporate mainframe systems. We specialize in preparing applications and the associated data that are currently residing on a single platform to be distributed across a variety of platforms. Preparing the application programs will require the transfer of source members that will be compiled and deployed on the target platform. The data will need to be transferred between the systems and may need to be converted and validated at various stages within the process. SimoTime has the technology, services and experience to assist in the application and data management tasks involved with doing business in a multi-system environment. Whether you want to use the Internet to expand into new market segments or as a delivery vehicle for existing business functions simply give us a call or check the web site at http://www.simotime.com
|