Totals & Record Counts Sequential File with Zoned-Decimal |
The SimoTime Home Page |
The SimoTime Technologies have the capability of generating a COBOL program that will read a Data File or VSAM Data Set and calculate a record count and accumulate summary totals for the user-defined, numeric fields within a record. The format of the numeric fields is zoned decimal. Once the record count and summary totals are accumulated they are written to a user-defined output device that may be a file or a SYSOUT device.
The execution of this suite of programs is the 2nd task within a group of three (3) tasks.
Explore how to Create Test Data Files. For this suite of jobs and programs the file format will be record sequential and the record format will be a fixed-length of 80-byte records containing text strings and zoned-decimal numeric fields.
Explore how to Calculate a Record Count and Accumulate Summary Totals by reading a Record Sequential Data File. Each record contains numeric fields with a Zoned-Decimal (USAGE IS DISPLAY) format. The count and totals will be posted to the SYSOUT device.
Explore how to Validate the Content of Two Data Files by doing a record-by-record compare of two sequential files with 121-byte records. The COBOL source code for the program was generated using SimoTime technologies. This suite of programs was originally inteneded to compare two SYSOUT files since a SYSOUT device is typically configured as a record sequential file with 121-byte records.
This suite of programs is used by SimoTime as a regression test for processing (i.e. accumulating summary totals) numeric information that is stored in a Zoned-Decimal (USAGE IS DISPLAY) format. The primary objective is to create the summary totals for each of the numeric fields. The secondary objective is to validate the content each of the numeric fields.
Note: One of the challenges of using the Zoned-Decimal format is the possibility of a field containing a non-numeric value. If this happens the program processing the field must be able to recognize the condition and execute alternate processing to avoid a system error and subsequent abnormal termination of the program.
The "Execute" section of this document will describe and demonstrate how to run a job that will read a file and post the summary totals to a SYSOUT file. The "Prepare" section of this document will describe and demonstrate how to generate the programs that will accumulate summary totals and record counts.
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-2024
SimoTime Technologies and Services
All Rights Reserved
This section will describe and demonstrate how to run a job that will read a file and post the summary totals to a SYSOUT file.
The following shows the logic and data flow for the job that accumulates summary totals and record counts.
| |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Note-1: SYSUT1 identifies an ASCII/Text or Line Sequential (LSEQ) file containing summary totals and record counts. | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Note-2: Within the SYSUT1 records the Zoned-Decimal format is used for the numeric fields. | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Note-3: SYSOUT is configured to be an ASCII/Text file with a maximum record length of 121 bytes. |
Accumulate Summary Totals and Record Counts |
The following Windows Command File (ZDTOTSW1.cmd) will set the environment and execute the program that accumulates the summary totals and record counts for the 1st data file.
@echo OFF rem * ******************************************************************* rem * ZDTOTSW1.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 - Read a file, Calculate record count and numeric totals. rem * Author - SimoTime Technologies rem * Date - January 24, 1988 rem * rem * The job will read a record sequential file of 80-byte records that rem * contains numeric fields within the records. rem * The programs will read the file and calculate summary totals for rem * user-defined numeric fields and a record count for the file. rem * The information will then be posted to the SYSOUT device. rem * rem * ************ rem * * ZDTOTSW1 * rem * ********cmd* rem * * rem * * rem * ************ ************ ************ rem * * SYSUT1 ******* ZDTOTSV1 ******* SYSOUT * rem * *******rseq* ********cbl* *******lseq* rem * * rem * * rem * ************ rem * * EOJ * rem * ************ rem * rem * Note: ZDTOTSV1 calls ZDTOTSR1 rem * rem * This set of programs will run on a Windows System with Micro Focus rem * Enterprise Developer. rem * rem * ******************************************************************* rem * Read a File, Calculate Record Counts and Summary Totals... rem * set CmdName=ZDTOTSW1 call ..\Env1BASE %CmdName% if "%SYSLOG%" == "" set syslog=c:\SimoLIBR\LOGS\SimoTime.LOG rem * call SimoNOTE "*******************************************************%CmdName%" call SimoNOTE "Starting CmdName %CmdName%" rem * rem * ******************************************************************* call SimoNOTE "StepInfo Prepare the environment" set SYSUT1=%BaseLib1%\DATA\ASC1\SIMOTIME.RSEQ.ZDTOTSD1.DAT set SYSOUT=%BaseLib1%\LOGS\SYSOUT_%CmdName%.TXT if exist %SYSOUT% erase %SYSOUT% rem * rem * ******************************************************************* call SimoNOTE "StepInfo Execute the Program to Calculate Totals" call SimoNOTE "DataTake %SYSUT1%" call SimoNOTE "DataMake %SYSOUT%" run ZDTOTSV1 if not "%ERRORLEVEL%" == "0" set JobStatus=0010 if not %JobStatus% == 0000 goto :EojNok if exist %SYSOUT% type %SYSOUT% goto :EojAok rem * rem * ******************************************************************* :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
The following Windows Command File (ZDTOTSW2.cmd) will set the environment and execute the program that accumulates the summary totals and record counts for the 2nd data file.
@echo OFF rem * ******************************************************************* rem * ZDTOTSW2.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 - Read a file, Calculate record count and numeric totals. rem * Author - SimoTime Technologies rem * Date - January 24, 1988 rem * rem * The job will read a record sequential file of 80-byte records that rem * contains numeric fields within the records. rem * The programs will read the file and calculate summary totals for rem * user-defined numeric fields and a record count for the file. rem * The information will then be posted to the SYSOUT device. rem * rem * ************ rem * * ZDTOTSW2 * rem * ********cmd* rem * * rem * * rem * ************ ************ ************ rem * * SYSUT1 ******* ZDTOTSV1 ******* SYSOUT * rem * *******rseq* ********cbl* *******lseq* rem * * rem * * rem * ************ rem * * EOJ * rem * ************ rem * rem * Note: ZDTOTSV1 calls ZDTOTSR1 rem * rem * This set of programs will run on a Windows System with Micro Focus rem * Enterprise Developer. rem * rem * ******************************************************************* rem * Read a File, Calculate Record Counts and Summary Totals... rem * set CmdName=ZDTOTSW2 call ..\Env1BASE %CmdName% if "%SYSLOG%" == "" set syslog=c:\SimoLIBR\LOGS\SimoTime.LOG rem * call SimoNOTE "*******************************************************%CmdName%" call SimoNOTE "Starting CmdName %CmdName%" rem * rem * ******************************************************************* call SimoNOTE "StepInfo Prepare the environment" set SYSUT1=%BaseLib1%\DATA\ASC1\SIMOTIME.RSEQ.ZDTOTSD2.DAT set SYSOUT=%BaseLib1%\LOGS\SYSOUT_%CmdName%.TXT if exist %SYSOUT% erase %SYSOUT% rem * rem * ******************************************************************* call SimoNOTE "StepInfo Execute the Program to Calculate Totals" call SimoNOTE "DataTake %SYSUT1%" call SimoNOTE "DataMake %SYSOUT%" run ZDTOTSV1 if not "%ERRORLEVEL%" == "0" set JobStatus=0010 if not %JobStatus% == 0000 goto :EojNok if exist %SYSOUT% type %SYSOUT% goto :EojAok rem * rem * ******************************************************************* :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
This section shows the content of the two SYSOUT files. In the 1st Job the field name "ZDTOTS01-VALUE-03" contains a value of 570. In the 2nd job the same field contains a value of 572.
This difference will be programmatically identified by the compare process that is executed as part of the 3rd task within this group of three (3) tasks.
The following is an example of the output produced by the 1st job. This example shows the summary totals for the user-defined field and the record count for the test file.
* NBRZD3C1 Zoned Decimal with non-Numeric v15.05.22 helpdesk@simotime.com * NBRZD3C1 A Program to Calculate Totals was generated by SimoTime Technologies * NBRZD3C1 * HEX20 parameter is DISABLE * NBRZD3C1 * HEX40 parameter is DISABLE * NBRZD3C1 * HEXTR parameter is DISABLE * NBRZD3C1 * NUMCHK parameter is ENABLE * NBRZD3C1 ************************************************************************************************************ * NBRZD3C1 Field Name Summary.Total HEX40 HEX20 NUMCHK TYPE * NBRZD3C1 NBRZD3B1-RECID-R01 3 ZD * NBRZD3C1 NBRZD3B1-FIELD-01 123 ZD * NBRZD3C1 NBRZD3B1-FIELD-02 1,368- ZD * NBRZD3C1 NBRZD3B1-FIELD-03 1,230 ZD * NBRZD3C1 NBRZD3B1-FIELD-04 199,998 ZD * NBRZD3C1 Record count for SYSUT1 000000003 * NBRZD3C1 Field Name Summary.Total HEX40 HEX20 NUMCHK TYPE * NBRZD3C1 ************************************************************************************************************ * NBRZD3C1 Program to Calculate Totals generated by using SimoTime Technologies * NBRZD3C1 Please send all comments or suggestions to the helpdesk@simotime.com
The following is an example of the output produced by the 2nd job. This example shows the summary totals for the user-defined field and the record count for the test file.
* ZDTOTSV1 Accumulate Zoned Decimal Fields v15.05.18 helpdesk@simotime.com * ZDTOTSV1 A Program to Calculate Totals was generated by SimoTime Technologies * ZDTOTSV1 * HEX20 parameter is DISABLE * ZDTOTSV1 * HEX40 parameter is DISABLE * ZDTOTSV1 * HEXTR parameter is DISABLE * ZDTOTSV1 * NUMCHK parameter is ENABLE * ZDTOTSV1 ************************************************************************************************************ * ZDTOTSV1 Field Name Summary.Total HEX40 HEX20 NUMCHK TYPE * ZDTOTSV1 ZDTOTS01-VALUE-01 1,235,802,647.09 ZD * ZDTOTSV1 ZDTOTS01-VALUE-02 1,416.660 ZD * ZDTOTSV1 ZDTOTS01-VALUE-03 572 ZD * ZDTOTSV1 Record count for SYSUT1 000000008 * ZDTOTSV1 Field Name Summary.Total HEX40 HEX20 NUMCHK TYPE * ZDTOTSV1 ************************************************************************************************************ * ZDTOTSV1 Program to Calculate Totals generated by using SimoTime Technologies * ZDTOTSV1 Please send all comments or suggestions to the helpdesk@simotime.com
Before the jobs can be executed some preparation work will be required. The validation programs (summary totals and record count) need to be generated. Test data will need to be created. The environment will need to be configured. The programs will need to be compiled and the executable members will need to be promoted to the load library.
This section will describe the Process Control File and how it is used to generate and compile the programs that will do the file read and accumulation of summary totals with a record count.
The following Process Control File (ZDTOTSV1.pcf) is used to generate the program that accumulate the summary totals and record counts.
*********************************************************************** * ZDTOTSV1.pcf - a Process Control File * * SimoTime Program Generation Technologies * * (C) Copyright 1987-2019 All Rights Reserved * * Web Site URL: http://www.simotime.com * * e-mail: helpdesk@simotime.com * *********************************************************************** * SYSUT1 is the Sequential File with 80-byte records. *********************************************************************** * This Process Control File will be used to generate a set of COBOL * programs that will accumulate totals for user-defined numeric fields * and provide a record count. * Refer to the utconv01.htm document for additional detail. * * The following group of statements will define the high level * functions and processes to be performed. * &SIMOPREP call ..\ENV1BASE &USERPREP call USERCOGI &CONFORM IBM ©FILE ZDTOTSB1.cpy &HTMLFILE zdtotsb1.htm * * The following group of statements will define the behavioral * characteristics and environment variable for the file I/O Program * to be generated. * *HEAD34 ....:....1....:....2....:....3.... &HEAD34 Accumulate Zoned Decimal Fields &PROGID ZDTOTSV1 &SYSUT1 org=Sequential recfm=FIXED rlen=80 * * The following group of statements will define the behavioral * characteristics and environment variables for the record content * conversion program to be generated. * The following defines the name of the callable routine for special * numeric processing. * &NUMCALL ZDTOTSR1 &NUMREC ZDTOTSD1-RECORD * * The following statement will look at the user-defined numeric fields * and compensate when the field contains non-numeric values. * characters. * &NUMCHK ENABLE * * The following group of statements will define the type of processing * and the name of the numeric fields. * &UT1TOTAL ZDTOTS01-VALUE-01 &UT1TOTAL ZDTOTS01-VALUE-02 &UT1TOTAL ZDTOTS01-VALUE-03 * &END
The SimoTime Technologies are used to generate the COBOL programs that will actually read a file and produce a report that contains summary totals for user-defined fields and a record count for the number of records in the file.
Explore How to Generate a Data File Compare, Validate or Hex-Dump Program using simple specification statements in a Process Control File (PCF). This link to the User Guide includes the information necessary to create a Process Control File and generate the COBOL programs that will do a data file compare, accumulate summary totals with a record count or produce a Hex-Dump of records in a VSAM, KSDS based on a list of user-defined keys. The User Guide contains a list of the PCF statements that are used for the data file compare, validate or dump process.
For the Micro Focus environment the programs are compiled using the following compiler directives.
DIALECT"ENTCOBOL" CHARSET"ASCII" ASSIGN"EXTERNAL" IDXFORMAT"8" IBMCOMP NOTRUNC HOSTNUMMOVE HOSTNUMCOMPARE NOSIGNFIXUP HOSTARITHMETIC NOHOSTFD CHECKNUM ANIM COBIDY NOOPTIONAL-FILE outdd"SYSOUT 121 L" SHARE-OUTDD DATE TIME DATAMAP settings list() noform
The following links will provide additional information about the Micro Focus compiler directives.
Explore the Compiler Directives available for the Micro Focus COBOL technologies.
This section provides additional details about the programs and control files that are used in this suite of programs.
The file format for the test file is record sequential with a fixed record length of eighty (80) bytes. The record content has one text string and three (3) numeric fields that are defined as packed-decimal (or COMP-3) format.
The following source member (ZDTOTSB1.cpy) is the COBOL Copy File that defines the record structure for the test file.
***************************************************************** * ZDTOTSB1.cpy - a COBOL Copy File * * A Record Structure Containing Numeric Fields * * Zoned-Decimal Format or USAGE IS DISPLAY * * Used for Calculating and Testing CheckSum Totals * * 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 * ***************************************************************** * 01 ZDTOTSD1-RECORD. 01-80 05 ZDTOTS01-ALPHA-01 PIC X(32). 01-32 05 FILLER PIC X. 33-33 05 ZDTOTS01-VALUE-01 PIC 9(10)V99 USAGE IS DISPLAY. 34-45 05 FILLER PIC X. 46-46 05 ZDTOTS01-VALUE-02 PIC 9(8)V999. 47-57 05 FILLER PIC X. 58-58 05 ZDTOTS01-VALUE-03 PIC S9(5). 59-63 05 FILLER PIC X. 64-64 05 FILLER PIC X(16). 65-80 * * Note: Since "USAGE IS DISPLAY" is the default format for * numeric fields (i.e. PIC 9) it is typically not * explicitly coded. * *** ZDTOTSB1 - End-of-Copy File - - - - - - - - - - - ZDTOTSB1 * ***************************************************************** *
The SimoTime Technologies have the ability to scan a COBOL copy file and create an HTML document of a record structure or record layout. The HTML documentation provides information that is not easy to obtain by viewing the COBOL copy file. For example, the physical position of a field within a record as calculated during the copy file scan and placed in the HTML document.
Explore an HTML document that describes the Record Structure of the Test File used by the job that accumulates Summary Totals and calculates a record count. The numeric fields are zoned-decimal (or USAGE IS DSPLAY) format. The record structure and generated HTML document for this file are based on a User-Supplied COBOL copyfile.
The purpose of this document is to assist as a tutorial for new programmers or as a quick reference for experienced programmers that are interested in improving their testing process by leveraging additional functionality and data validation techniques.
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.
Software Agreement and Disclaimer
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.
This 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.
The 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 Packed-Decimal or COMP-3 format for numeric data strings. This numeric structure is supported by COBOL and may be explicitly defined with the "USAGE IS COMP-3" clause.
Explore how to process non-Numeric Values stored in a Zoned-Decimal format. This document will use examples to show how to manage a situation where non-numeric values are placed in a Zoned-Decimal field. The fields are then processed using techniques that will avoid a S0C7 or RTS 163 error message and an abnormal termination of the program.
Explore the Numbers Connection for additional information about the structure and processing of numeric data items (or numeric fields).
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 COBOL Connection for more examples of COBOL programming techniques and sample code.
Explore an Extended List of Software Technologies that are available for review and evaluation. The software technologies (or Z-Packs) provide individual programming examples, documentation and test data files in a single package. The Z-Packs are usually in zip format to reduce the amount of time to download.
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.
The following links will require an internet connection.
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.
Explore the Glossary of Terms for a list of terms and definitions used in this suite of documents and white papers.
This document was created and is maintained by SimoTime Technologies. If you have any questions, suggestions, comments or feedback please use the following contact information.
1. | Send an e-mail to our helpdesk. |
1.1. | helpdesk@simotime.com. |
2. | Our telephone numbers are as follows. |
2.1. | 1 415 763-9430 office-helpdesk |
2.2. | 1 415 827-7045 mobile |
We appreciate hearing from you.
SimoTime 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
Return-to-Top |
Summary Totals and Record Counts for Zoned Decimal Format |
Copyright © 1987-2024 SimoTime Technologies and Services All Rights Reserved |
When technology complements business |
http://www.simotime.com |