Sync Sort

Download as pdf or txt
Download as pdf or txt
You are on page 1of 594

All rights reserved.

This document contains proprietary and confidential material, and is only for use by licensees of the SyncSort for z/OS proprietary software system.

P R O V E N performance

SyncSort for z/OS


Programmer's Guide
Release 1.2
SyncSort is a registered trademark of Syncsort Incorporated

SI-4301-6 1.2

Syncsort Incorporated, 2005 All rights reserved. This document contains proprietary and confidential material, and is only for use by licensees of the SyncSort proprietary software system. This publication may not be reproduced in whole or in part, in any form, except with written permission from Syncsort Incorporated. SyncSort and Visual SyncSort are trademarks of Syncsort Incorporated. No claim is made to the exclusive right to use Visual apart from the mark as shown. All other company and product names used herein may be the trademarks of their respective companies.

Table of Contents

Summary of Changes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . v Chapter 1. Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . An Introduction to SyncSort for z/OS . . . . . . . . . . . . . . . . . . . . . . . . . . . SyncSorts Basic Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . SyncSorts Data Utility and SortWriter Features . . . . . . . . . . . . . . . . . . Sample SortWriter Report . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Cultural Environment Support . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . DB2 Query Support . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . SyncSorts Operational Features. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . SyncSorts Value-Added Products . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Structure of the Programmers Guide . . . . . . . . . . . . . . . . . . . . . . . . . . . . Related Reading . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Online Message Help . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1.1 1.1 1.1 1.3 1.5 1.5 1.6 1.6 1.6 1.7 1.9 1.9

Chapter 2.

SyncSort Control Statements . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2.1 Control Statement Summary Chart . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2.2 Disk Sort, MAXSORT, PARASORT, and Tape Sort Control Statement Requirements . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2.8 Data Utility Processing Sequence . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2.9 Control Statement Examples . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2.11 Rules for Control Statements . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2.11 ALTSEQ Control Statement . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2.16 END Control Statement . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2.18 INCLUDE/OMIT Control Statement . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2.19 INREC Control Statement . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2.38 JOIN Control Statement . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2.40 JOINKEYS Control Statement . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2.42 MERGE Control Statement . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2.46 MODS Control Statement . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2.61 OMIT Control Statement . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2.65 OUTFIL Control Statement . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2.66 OUTREC Control Statement . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2.97 RECORD Control Statement . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2.137 REFORMAT Control Statement . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2.141 SORT Control Statement . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2.144 SUM Control Statement . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2.164 How to Use SyncSorts Data Utility Features . . . . . . . . . . . . . . . . . . Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Sample Data Utility Applications . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Selecting Input Records . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Selecting Relevant Fields from the Input Records. . . . . . . . . . . . . . . . . . 3.1 3.1 3.2 3.2 3.6

Chapter 3.

Table of Contents

Combining Records within a File . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3.11 Joining Records from Multiple Files . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3.14 Making Output Records Printable and Easy to Read . . . . . . . . . . . . . . 3.23 Dividing a Report into Sections . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3.39 Writing Headers and Trailers for a Report . . . . . . . . . . . . . . . . . . . . . . 3.41 Totaling and Subtotaling Data . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3.50 Obtaining Maximum, Minimum and Average Data . . . . . . . . . . . . . . . 3.56 Counting Data Records . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3.58 Creating Multiple Output Files . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3.62 Chapter 4. JCL and Sample JCL/Control Statement Streams. . . . . . . . . . . . . . 4.1 EXEC Statement . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4.2 For MAXSORT, PARASORT, DB2 Query Support, and Tape Sort . . . . . 4.3 Coding Conventions for DD Statements . . . . . . . . . . . . . . . . . . . . . . . . . . 4.3 STEPLIB/JOBLIB DD Statement . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4.4 SYSOUT DD Statement . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4.4 SORTIN DD Statement . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4.5 SORTINnn or SORTINn DD Statement . . . . . . . . . . . . . . . . . . . . . . . . . 4.7 SORTJNF1 and SORTJNF2 DD Statements . . . . . . . . . . . . . . . . . . . . . . 4.8 SORTOUT, SORTOFxx, SORTOFx and SORTXSUM DD Statements . 4.8 SORTWKxx or SORTWKx DD Statement . . . . . . . . . . . . . . . . . . . . . . . 4.10 SYSIN DD Statement . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4.11 $ORTPARM DD Statement . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4.12 SORTCKPT DD Statement . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4.15 For Exit Routines that Require Link-editing at Execution Time . . . . . 4.15 DD Statements for MAXSORT, PARASORT, DB2 Query Support, and Tape Sort . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4.16 Sample JCL/Control Statement Streams . . . . . . . . . . . . . . . . . . . . . . . . 4.17 PARM Options . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Additional MAXSORT PARMs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . PARASORT PARM . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . DB2 Query Support PARM . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Additional Tape Sort PARMs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Precedence Rules . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . PARM Option Summary Chart . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . SyncSort PARM Options . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5.1 5.1 5.2 5.2 5.2 5.2 5.2 5.6

Chapter 5.

Chapter 6.

Invoking SyncSort from a Program . . . . . . . . . . . . . . . . . . . . . . . . . . 6.1 Programming Flexibility vs. Performance. . . . . . . . . . . . . . . . . . . . . . . . . 6.1 DD Statements . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6.1 Invoking the Sort/Merge from an Assembler Program . . . . . . . . . . . . . . 6.2 The 24-Bit Parameter List . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6.4 Sample Assembler Invocation Using 24-Bit Parameter List . . . . . . . . . 6.12 The 31-Bit Extended Parameter List . . . . . . . . . . . . . . . . . . . . . . . . . . . 6.13 Sample Assembler Invocation Using 31-Bit Parameter List . . . . . . . . . 6.18 The Coding and Use of Exit Programs . . . . . . . . . . . . . . . . . . . . . . . . What Is an Exit? . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Loading the Exit Routines into Main Storage . . . . . . . . . . . . . . . . . . . . . Exit Conventions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Register Conventions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . The Exit Communication Area . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Exits E11, E21, and E31 - Preparing for Other Exit Routines . . . . . . . . Exit E32 - Invoked Merge Only: Creating Input Records . . . . . . . . . . . . Exit E14 - Deleting, Summarizing, Changing Records . . . . . . . . . . . . . . Exit E15 - Creating, Revising, or Analyzing the Input File . . . . . . . . . . Coding a COBOL E15 Exit Routine . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7.1 7.1 7.3 7.3 7.4 7.4 7.5 7.5 7.6 7.7 7.9

Chapter 7.

ii

SyncSort for z/OS 1.2 Programmers Guide

Example 1: Fixed-Length Records . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7.10 Example 2: Variable-Length Records . . . . . . . . . . . . . . . . . . . . . . . . . . . 7.11 Coding a C E15 Exit Routine. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7.19 Fixed-Length Records - Function Definition . . . . . . . . . . . . . . . . . . . . . 7.20 Variable-Length Records - Function Definition . . . . . . . . . . . . . . . . . . . 7.21 Exit E25 - Deleting, Changing, and Summarizing Records . . . . . . . . . 7.27 Exit E35 - Adding, Deleting, and Changing Records . . . . . . . . . . . . . . 7.28 Coding a COBOL E35 Exit Routine . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7.30 Coding a C E35 Exit Routine . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7.43 Fixed-Length Records - Function Definition . . . . . . . . . . . . . . . . . . . . . 7.43 Variable-Length Records - Function Definition . . . . . . . . . . . . . . . . . . . 7.45 Exit E16-Taking Action on Insufficient Intermediate Storage . . . . . . . 7.51 Exits E17, E27, and E37 - Closing Data Sets . . . . . . . . . . . . . . . . . . . . 7.52 Exits E18, E38, and E39 - Checking Labels, Processing Read or Write Errors, End-of-File Routines, Special VSAM Processing . . . . . . . . . 7.52 Exit E61 - Modifying the Collating Process . . . . . . . . . . . . . . . . . . . . . . 7.56 Coding REXX Exits . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7.58 Chapter 8. Chapter 9. The Flow of the Sort . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8.1 MAXSORT. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9.1 MAXSORT: A Maximum Capacity Sort . . . . . . . . . . . . . . . . . . . . . . . . . . 9.1 MAXSORTs Advantages . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9.4 Job Control Language . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9.4 DD Statements . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9.4 SORTBKPT DD Statement . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9.6 SORTOU00 DD Statement . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9.7 SORTOUnn DD Statements . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9.8 Using Disk for Intermediate Output. . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9.9 SORTCKPT DD Statement . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9.9 Control Statements . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9.10 PARM Options . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9.10 Exit Programs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9.13 Invoking MAXSORT from a Program . . . . . . . . . . . . . . . . . . . . . . . . . . 9.13 Restarting MAXSORT . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9.14 MAXSORTs Operator Interface . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9.14 Sample MAXSORT JCL/Control Streams . . . . . . . . . . . . . . . . . . . . . . . . 9.17 PARASORT. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10.1 PARASORT: Parallel Input Processing for Elapsed Time Improvement 10.1 PARASORT Applicability . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10.1 Job Control Language . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10.2 DD Statements . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10.3 SORTIN DD Statement with PARASORT . . . . . . . . . . . . . . . . . . . . . . . 10.3 SORTPARn DD Statements . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10.5 Special Channel Separated Esoteric Names . . . . . . . . . . . . . . . . . . . . . 10.7 Sortwork Considerations . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10.8 Operations Notes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10.9 SyncSort DB2 Query Support . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Restrictions. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Job Control Language . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . DD Statements . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . SORTDBIN DD Statement . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Operation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Record Description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Record Description: Trial Mode Execution . . . . . . . . . . . . . . . . . . . . . . . Sample SyncSort DB2 Query Application . . . . . . . . . . . . . . . . . . . . . . . 11.1 11.1 11.2 11.2 11.3 11.4 11.4 11.5 11.7

Chapter 10.

Chapter 11.

Table of Contents

iii

Chapter 12.

Tape Sort. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12.1 When to Use Tape Sort . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12.1 EXEC Statement. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12.2 DD Statements . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12.3 SORTLIB DD Statement . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12.3 SORTWKxx DD Statement . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12.4 $ORTPARM DD Statement . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12.5 Optimizing Tape Sort . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12.5 Control Statements . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12.6 Exit Programs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12.6 Initiating Tape Sort Through JCL/Control Streams . . . . . . . . . . . . . . . 12.7 Invoking Tape Sort from a Program . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12.9 Performance Considerations . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13.1 Disk Sort? MAXSORT? PARASORT? Tape Sort? . . . . . . . . . . . . . . . . . 13.1 JCL Sorts vs. Program-Invoked Sorts . . . . . . . . . . . . . . . . . . . . . . . . . . 13.2 Control Statement Issues . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13.2 The Efficient Use of PARMs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13.3 Optimizing System Resources . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13.4 Setting CORE . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13.4 The Incore Sort . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13.6 Disk Space Considerations . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13.7 The Coding and Use of Checkpoint-Restart . . . . . . . . . . . . . . . . . . . . . . 13.9 Automatic Checkpoint-Restart. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13.11 Deferred Checkpoint-Restart . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13.12 Optimizing Data Set Placement . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13.13 The HISTOGRM Utility Program . . . . . . . . . . . . . . . . . . . . . . . . . . . 14.1 What Is HISTOGRM? . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14.1 Using HISTOGRM to Determine L6 and L7 Values for SyncSort . . . . . 14.2 Control Parameters for HISTOGRM . . . . . . . . . . . . . . . . . . . . . . . . . . . 14.2 Job Control Language . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14.4 Executing HISTOGRM through an E15 Exit . . . . . . . . . . . . . . . . . . . . . 14.4 HISTOGRM Messages . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14.9 Value-Added Products . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Visual SyncSort. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . PROC SYNCSORT - An Accelerator for SAS Sorting . . . . . . . . . . . . . PipeSort . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15.1 15.1 15.2 15.3

Chapter 13.

Chapter 14.

Chapter 15.

Chapter 16.

Messages . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16.1 SyncSort Statistical Record Facility Messages . . . . . . . . . . . . . . . . . . 16.69 PROC SYNCSORT Messages . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16.70 License Key Messages . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16.71 Troubleshooting Abends . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16.75 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . I.1

Index

iv

SyncSort for z/OS 1.2 Programmers Guide

SyncSort for z/OS Release 1.2 - Summary of Changes

Performance Improvements
SyncSort for z/OS performance has been improved by the following. SyncSorts ZSPACE technique introduced in Release 1.1 of SyncSort for z/OS has been extended to eliminate the use of hiperspace and to employ 64-bit virtual storage (memory objects) when appropriate. These enhancements will improve CPU time and elapsed time. Enhancements have been made to the techniques that exploit parallel access volume (PAV) technology. These changes allow more cases to benefit from this technology, improving their elapsed time results. Elapsed time performance improvements have been made for many merge/copy applications. Requirements for real storage below the line have been significantly reduced. This enhancement improves system-wide performance by providing below the line real storage constraint relief. Requirements for real storage below the bar have been significantly reduced. This helps to provide system-wide real storage constraint relief for environments with more than 2 gigabytes of real storage available. Requirements for virtual storage below the line have been significantly reduced. This allows an application to run with a reduction of up to 60K of storage below the line when the application is required to share storage with other programs or other instances of SyncSort that have been multiply invoked within an address space. CPU performance has been improved in the following types of sort applications: Those that use the OUTREC CONVERT feature, which enables the conversion of variable-length records into fixed-length records. Those that use E11, E21, or E31 exits.

Summary of Changes

Those that use the CKPT/CHKPT parameter of the SORT control statement. This parameter instructs SyncSort to take a checkpoint at every end-of-volume of a SORTOUT data set when OUTFIL is not used and also at the beginning of Phase 3 before the SORTOUT data set is opened.

Local DSM has been enhanced to provide coordination of storage use between concurrent executions of SyncSort applications. Although the system monitoring and history information available to the global DSM feature provides optimal selection of appropriate storage resources, this enhancement, when compared to the prior releases of local DSM, provides better coordination for applications that begin execution within a short time interval of each other.

Data Utility Features


The SyncSort for z/OS data utility features have been enhanced by the following.

Join Processing
The join facility gives you the capability to join records from two source files. When you join the records from two files, each record from the first file with a given value in a specified field (the join key) is joined to each record from the second file with the identical value in a specified field in that record. Options are provided to control several aspects of the join operation. Specification of the placement of the data fields within the record created by the join operation. The ability to eliminate records from either or both of the two input files prior to join processing. Specification of whether the join input data is already sorted per the control fields to be used in the join operation. If the join input data set is already sequenced, the overall performance of the application will be improved. Specification of an inner join, left outer join, right outer join, or full outer join. The ability to retain only the records that were not matched during join processing (outer join only).

The join operation is controlled by the following three new control statements: JOIN Statement The JOIN statement specifies the disposition of paired and unpaired records in a join. JOINKEYS Statement

vi

SyncSort for z/OS 1.2 Programmers Guide

The JOINKEYS statement enables join feature processing and identifies the fields used to select records for join processing. REFORMAT Statement The REFORMAT statement defines the record layout to be produced by the join processing specified on an applications JOINKEYS control statements.

Other Enhancements
INCLUDE/OMIT Control Statement The FORMAT subparameter can now be specified along with format values for individual fields in the COND parameter. If a format value for an individual field is omitted, the FORMAT subparameter is used. A new &DATE4 subparameter provides a new form for a current date constant. For a substring comparison, the maximum length of the record field has been increased from 256 to 32752 bytes.

OUTFIL Control Statement The REPEAT parameter has been added. REPEAT enables each output record to be written multiple times. The SAMPLE parameter has been added. SAMPLE allows the selection of a sample of records for processing in an OUTFIL group. The SPLITBY parameter has been added. SPLITBY enables groups of records to be written in rotation among multiple output data sets. The COUNT and SUBCOUNT TRAILER subparameters have been enhanced to provide editing of their output with MASKs, SIGNs, and LENGTH specifications.

OUTREC Control Statement The MOD (modulus) operator has been added to the arithmetic functions provided in expressions. The &DATE4 current date constant has been added. This provides an additional format to display the current date in a record. Applications that have VSAM input, do not specify a RECORD TYPE parameter, and have an OUTREC statement with the CONVERT parameter will now process the VSAM input as variable-length data. Previously, the VSAM input was processed as fixed-length data, and the CONVERT parameter was therefore ignored.

Summary of Changes

vii

SORT/MERGE Control Statements For variable-length records, sort or merge control fields may now be specified anywhere in the first 32750 bytes of the record. The prior limit was the first 4084 bytes.

IOERR Parameter The IOERR=NOSNAP option has been added. Specify IOERR=NOSNAP to receive a user abend 999 if an I/O error should occur. This abend will cause the step to terminate, but no diagnostic dump will be produced, unless the DEBUG option is in effect.

Automatic Secondary Allocation Automatic secondary allocation will be performed for SORTWK data sets by default. This was previously controlled by the SECOND parameter.

Messages
Message WER072I indicates the status of the EQUALS and RESET options when applicable. Messages WER469A, WER470A, WER473A, and WER477A indicate that a join application requires two JOINKEYS statements that define the same number of JOINKEYS FIELDS, with each corresponding field having the same length and order specified. Message WER471A indicates that a join application requires a REFORMAT control statement, unless a JOIN UNPAIRED control statement is present with the ONLY parameter specified. Message WER472A indicates that the maximum number of JOINKEYS FIELDS that may be specified is 64. Message WER474A indicates that the maximum total length of all JOINKEYS FIELDS is 4080 bytes. Message WER476A indicates that when a variable-length record is defined as the output of the JOINKEYS feature, the first four bytes defined must be for an RDW. Message WER478A indicates that a join application requires the presence of SORTJNF1 and SORTJNF2 DD definitions in the JCL.

viii

SyncSort for z/OS 1.2 Programmers Guide

Message WER479A indicates that a join application may not be specified with any of the following parameters: MAXSORT, PARASORT, PIPESORT, SKIPREC, the MERGE function, user exits (except E35), CHECKPOINT, or DB2. Message WER480A indicates that a REFORMAT FIELD may only be specified as a position without a length value if it refers to a file defined as variable-length. Message WER481I indicates the record length after JOINKEYS processing. Message WER482I indicates information on SORTJNF1 or SORTJNF2 processing that was performed during a join application. Message WER483B details characteristics of the sort processing performed for SORTJNF1 or SORTJNF2 to prepare them for the join operation. Message WER484I indicates the ddname of a particular join input file, the number of records read from the file, the number of records deleted by the JOINKEYS INCLUDE/OMIT parameter, the number of records matched during join processing, and the number of records that were unpaired during join processing. Message WER485A indicates that a sequence error was detected in either SORTJNF1 or SORTJNF2. Message WER486A indicates an error that has occurred while processing the SORTJNF1 or SORTJNF2 data sets. Message WER487I indicates the number of bytes of SORTJNF1 or SORTJNF2 input data sorted by SyncSort to prepare the file for join match field processing. Message WER488A indicates that SyncSort is unable to complete a join application because of insufficient memory. In a SyncSort merge application, each SORTINnn input file must be pre-sequenced. If an out-of-sequence condition is found, WER068A OUT OF SEQ SORTINxx is issued and SyncSort terminates. Previously, SyncSort did not issue WER068A if any of the out-of-sequence records were variable-length and did not contain all of the MERGE control fields. WER068A will now be issued whenever any out-of-sequence input file is detected. Note that the SyncSort VLTEST option default does not allow the processing of any variable-length records that do not contain all of the SORT or MERGE control fields. Therefore, this change can only affect applications where this option has been changed to permit the processing of short variable-length records.

Summary of Changes

ix

SyncSort for z/OS 1.2 Programmers Guide

Chapter 1. Introduction

An Introduction to SyncSort for z/OS


SyncSort for z/OS is a high performance sort/merge/copy utility. It is designed for the advanced facilities of the zSeries architecture, but also supports the system architectures of IBM System/390 and compatible computers. It exploits the features of the z/OS operating system but will also execute under OS/390. SyncSort is designed to conserve system resources, provide significant performance benefits, and operate efficiently in 31-bit or 64-bit environments. SyncSort can be initiated through job control language or invoked from a program written in COBOL, PL/1, or Assembler language. A JCL-initiated sort is more efficient because SyncSort totally controls the sort execution, including I/O management and main storage management. Exit routines may be written in COBOL, C, FORTRAN, REXX, or Assembler language to give a JCL sort additional programming flexibility. Exits may also be in PL/1 when SyncSort is invoked by a PL/1 program.

SyncSorts Basic Functions


SyncSort has three basic functions: Sorting - rearranging data set records to produce a specific sequence. Merging - combining up to 100 pre-sequenced data sets into one data set which has the same sequence.

Chapter 1. Introduction

1.1

Copying - reproducing a data set without going through the sorting process.

Sorting
A sort rearranges the records in a data set to produce a specific sequence, e.g., chronological or alphabetic order. SyncSort provides the following sorting techniques: Disk Sort, the standard sorting technique. Information in the Programmers Guide refers to the Disk Sort unless otherwise indicated. MAXSORT, a maximum capacity sorting technique with an enhanced breakpoint/ restart capability. MAXSORT can sort any collection of data - regardless of size - using a limited amount of disk space. MAXSORT is described in the MAXSORT chapter of this guide. PARASORT, a sorting technique that significantly reduces elapsed time for sorts whose input is a multi-volume tape data set and/or concatenated tape data sets. PARASORT improves performance by using multiple tape drives in parallel. PARASORT is described in the PARASORT chapter of this guide.

A sort logically consists of four phases that perform the following functions: The control statements and JCL information are read and analyzed and the operational parameters for the sort are established. The input data is read into main storage and sorted. If necessary, intermediate results are written to temporary storage devices. The sorting process completes and the sorted data is written to the specified output device(s).

Merging
A merge combines up to 100 pre-sequenced data sets into one data set which has the same sequence. A merge has two phases that perform these functions: The control statements and JCL information are read and analyzed and the operational parameters for the merge are established. The files are merged and the merged data is written to the specified output device(s).

Copying
A copy reproduces a file, completely bypassing the sorting process. A copy has two phases that perform these functions:

1.2

SyncSort for z/OS 1.2 Programmers Guide

The control statements and JCL information are read and analyzed and the operational parameters for the copy are established. The copied file is written to the specified output device(s).

SyncSorts Data Utility and SortWriter Features


SyncSort is designed to improve programmer productivity by reducing the time the programmer/analyst must spend designing, testing, and debugging applications. With SyncSorts extensive Data Utility and SortWriter features, data processing applications previously requiring several steps can be accomplished in a single execution. SyncSorts Data Utility features include a join facility, a multiple output facility, a full range of report writing capabilities, and record selection and record reformatting facilities. These options allow the user to design sort/merge/copy applications that can accomplish a host of related tasks.

Join Processing
The join facility, controlled by the JOINKEYS, JOIN, and REFORMAT control statements, joins records from two source files. When you join the records from two files, each record from the first file (the left side) with a given value in a specified field (the join key) is joined to each record from the second file (the right side) with the identical value in a specified field in that record. Thus, if m records from the left side have a given join key value, and n from the right side have the same join key value, the join results in m*n records with that join key value. Options are provided to control several aspects of the join operation. Specification of the placement of the data fields within the record created by the join operation is provided through the REFORMAT control statement. This allows you to specify which fields from the two records are to be placed in the joined record. Partially or completely missing fields will be filled into the resulting joined record by the use of a specified pad byte. Record selection via the INCLUDE/OMIT parameter of the JOINKEYS statement eliminates records from either or both of the two input files prior to join processing. Specification of whether the join input data is already sorted per the JOINKEYS control fields is controlled by the SORTED parameter on the JOINKEYS control statement. If the join input data set is already sequenced according to the specified JOINKEYS fields, the overall performance of the application improves. Inner join, left outer join, right outer join, and full outer join are all supported through the use of the JOIN control statement.

Chapter 1. Introduction

1.3

Generating Multiple Output


The multiple output facility (OUTFIL) allows multiple output files to be generated with just one pass of the sort. Each of these files can have unique specifications that determine which records are to be included, how the records are to be formatted, and which report capabilities are to be used. Moreover, all these files can be written to the same output device, or each can be written to a different device.

Creating Reports
SyncSorts SortWriter feature (OUTFIL) allows the user to design comprehensive reports easily and efficiently. SortWriter options allow output data to be flexibly formatted with headers and trailers, which can include data fields. Various kinds of numeric results can be produced at report, page, and section levels. These include totals, subtotals, minimums, subminimums, maximums, submaximums, averages, subaverages, record counts, and subcounts. Output record fields can be realigned; the records can be padded with blanks, characters, and binary zeros; and numeric data can be converted and edited. Automatic pagination, page numbering, and dating are also provided.

Selecting Records, Reformatting Records, and Summarizing Fields


Record selection, record reformatting, and summing are other important SyncSort Data Utility features. Record selection via the INCLUDE/OMIT feature permits certain records to be included or omitted from an input data set based on comparisons between two data fields or between a data field and a constant. Date data formats work with the CENTWIN option to ensure that century evaluation is applied to INCLUDE/OMIT comparisons involving 2-digit year data. Record reformatting after input and/or before output, provided by the INREC/OUTREC capability, allows the user to delete or repeat portions of records; insert spaces, characters, binary zeros, date constants and sequence numbers; realign fields; convert numeric data to its printable format; and convert data to its printable hexadecimal format. The CENTWIN option and date data formats enable conversion of 2-digit year fields to printable or packed decimal 4-digit years of the appropriate century. The ability to delete irrelevant fields before sorting via INREC can provide important performance benefits. Additionally, a variable-length record format input file can be converted into a fixed-length format output file or a fixed-length record format input file can be converted into a variable-length format output file. The SUM feature allows records with equal sort control fields to be deleted and optionally summarizes numeric fields on those records. The deleted records can optionally be written to a separate data set.

1.4

SyncSort for z/OS 1.2 Programmers Guide

Sample SortWriter Report


The report below illustrates the versatility of SyncSorts Data Utility and SortWriter features. First, irrelevant records are omitted from the input file and the input record is reformatted to eliminate unnecessary data fields. Then the file is sorted by invoice status and invoice date. The output record is reformatted for readability and the numeric fields are converted and edited. The report itself is divided into sections and subsections based on control field breaks. Headers and trailers identify the data fields, provide record counts and section and cumulative totals, and include the date and page number.

ACCOUNTS RECEIVABLE AGING REPORT FOR 01/30/92 ********************************************* INVOICE STATUS:O ***************** -----------COMPANY NAME -----------REPUBLIC DATA RICE FEATURES SIDNEY COLLEGE WINIFRED INDUST PIZZUTO LOANS RICE FEATURES SIDNEY COLLEGE REGENCY TRUST CO SIDNEY COLLEGE ------- ---ADDRESS ------NYC NY CHI IL HOU TX WAS DC STL MO CHI IL HOU TX BOS MA HOU TX CO # ---2681 2244 4762 1177 4633 2244 4762 4986 4762 ----INV # ----86013306 86013298 86013297 86013299 86022200 86022198 86022197 85124011 85124016 -------INV DATE -------1/17/91 1/17/91 1/17/91 1/17/91 2/15/91 2/15/91 2/15/91 12/15/91 12/15/91 --------------------INVOICE PRODUCT TAX --------------------1,100.00 90.75 1,500.00 75.00 2,500.00 150.00 650.00 26.00 550.00 22.00 1,500.00 75.00 500.00 30.00 1,500.00 75.00 5,000.00 300.00 ---------$22,850.00 ---------650.00 1,700.00 1,750.00 850.00 1,600.00 750.00 360.00 600.00 ---------$8,260.00 ------------------$1,484.50 ---------29.25 76.50 70.00 51.00 64.00 45.00 21.60 36.00 ---------$393.35 ----------

PAGE: 3 DATE:04/22/92

--------------------BALANCE PRODUCT TAX --------------------1,100.00 90.75 1,500.00 75.00 2,500.00 150.00 650.00 26.00 550.00 22.00 1,500.00 75.00 500.00 30.00 1,500.00 75.00 5,000.00 300.00 ---------$22,850.00 ---------650.00 1,700.00 1,750.00 850.00 1,600.00 750.00 360.00 600.00 ---------$8,260.00 ------------------$1,484.50 ---------29.25 76.50 70.00 51.00 64.00 45.00 21.60 36.00 ---------$393.35 ----------

TOTAL NUMBER OF INVOICES:

11 MONTHLY TOTALS:

BALTIC AVENUE CORP FASTEROOT EQUIP FEDERAL FABRICS PATIO PRODUCTS TURENIUS FOR. EXCH. WINES ASSOCIATES DESIGN TECHNOLOGIES POLL DATA CORP

CLE BAL SHV MRY DTT SMF LAX LAX

OH MD LA CA MI CA CA CA

0636 4980 5143 3029 8325 1794 2520 0846

86022207 86022205 86022204 86022203 86022201 86022209 85124017 85124019

2/15/91 2/15/91 2/15/91 2/15/91 2/15/91 2/15/91 12/15/91 12/15/91

TOTAL NUMBER OF INVOICES:

8 MONTHLY TOTALS:

Figure 1. Sample SortWriter Report

Cultural Environment Support


Cultural environment support allows you to choose an alternate set of sort collating rules based on a specified national language. The alternate collating applies to SORT/MERGE and INCLUDE/OMIT processing. SyncSort employs the callable services of IBMs Language Environment for z/OS to collate data in a way that conforms to the language and conventions of a selected locale. A locale defines single and multi-character collating rules for a cultural environment. Numerous pre-defined locales are available. For additional information, see LOCALE on page 5.19.

Chapter 1. Introduction

1.5

DB2 Query Support


SyncSort can directly retrieve data from a DB2 database based upon a user provided query. An SQL SELECT statement is used to specify the criteria of the request, and the query of the DB2 database will be in place of SyncSort's SORTIN or E15 processing. SORT or COPY, but not MERGE, functions can be used with DB2 queries. All SyncSort features that are performed after E15 processing are available for use with the DB2 query facility. This feature improves performance over DB2s DSNTIAUL program by allowing DB2 data to be passed directly into a SORT or COPY operation, without the use of setup steps or the need for user-written E15 exits. Refer to Chapter 11. SyncSort DB2 Query Support for more information.

SyncSorts Operational Features


SyncSort will take advantage of data space and hiperspace to further improve performance. A portion of the address space may be allocated for SyncSort's ZSPACE technique. This technique was created as a replacement for hiperspace. It allows native use of the available central storage resources. This technique eliminates the additional overhead produced when hiperspace is simulated by the z/OS operating system in a z/Architecture environment. It provides superior CPU performance and reduced system overhead compared to a conventional hiperspace application. SyncSort can also interact with exits and invoking programs such as VS COBOL II, COBOL/370, C370 V2R1 with V2R2 C370 library, SAA AD/Cycle C370 Release 2, and IBM C/C++ V3R2 programs. SyncSorts PARMEXIT feature permits the dynamic modification of PARM values based on the conditions at execution time. This feature facilitates the passing of additional parameters to specific jobs. Other operational features include resident, reentrant code, interactive and streamlined installation and maintenance procedures; automatic release or secondary allocation of direct access intermediate storage (SORTWK) and output (SORTOUT) space without JCL specification; dynamic allocation of SORTWK space under z/OS (DYNALLOC); and automatic incore sorting.

SyncSorts Value-Added Products


Value-added products available from Syncsort can significantly improve sorting efficiency: Visual SyncSort for z/OS is a PC-based product designed to allow programmers and nonprogrammers alike to easily create and manage SyncSort for z/OS applications in the mainframe environment. With Visual SyncSort, you can create new sort, merge, and copy applications, or you can import and modify existing ones. Visual SyncSort saves programmer time while taking full advantage of the mainframe processing power of SyncSort for z/OS.

1.6

SyncSort for z/OS 1.2 Programmers Guide

PROC SYNCSORT - An Accelerator for SAS Sorting is a high performance, transparent replacement for the SAS procedure PROC SORT. Compared to PROC SORT, PROC SYNCSORT reduces the resources required for sorting within SAS applications and cuts sort elapsed time. PipeSort enables SyncSort to run multiple sorts simultaneously on the same input data. For large input files, PipeSort significantly reduces total elapsed time compared to running separate sort jobs. For more detailed information regarding each of these products, see Chapter 15. ValueAdded Products.

Structure of the Programmers Guide


The SyncSort for z/OS Programmers Guide is a reference manual designed for applications programmers who are using SyncSort to sort, merge, or copy sequential data sets. This manual is self-contained and assumes only a basic working knowledge of the operating system and its job control language. It should not be necessary to refer to any other manual to produce an efficient sort. SyncSort Control Statements describes how to specify and use the ALTSEQ, END, INCLUDE/OMIT, INREC/OUTREC, JOIN, JOINKEYS, MODS, OUTFIL, RECORD, REFORMAT, SORT/MERGE, and SUM statements. The discussion of a particular control statement includes these topics: the statements syntax format, the versatility provided by the various parameters (many of which are unique to SyncSort), and the interaction between the control statement and other statements. How to Use SyncSorts Data Utility Features explains and illustrates the Data Utility and SortWriter features through a series of sample applications. Each application is selfcontained and provides instructions for specifying both the required JCL and the appropriate control statements. JCL and Sample JCL/Control Statement Streams analyzes SyncSorts job control requirements and describes the SyncSort DD statements, each of which is illustrated with an example. JCL and control statement streams for MAXSORT and PARASORT are also described. Numerous examples are provided. PARM Options describes the operational parameters of SyncSort and identifies the delivered defaults. This chapter explains how to specify such features as dynamic allocation of SORTWK space under z/OS, automatic secondary allocation and release of SORTWK space, the ability to skip a certain number of records or stop after sorting a certain number of records, and message routing. Invoking SyncSort from a Program describes SyncSort invocation through assembler programs using 24-bit and 31-bit parameter lists. Numerous examples are provided.

Chapter 1. Introduction

1.7

The Coding and Use of Exit Programs indicates at which points during sort processing user-written exit routines can be executed. Each exit point is fully documented together with the appropriate tasks. Examples of COBOL E15 and E35 exit routines for fixed and variable-length records are included. The Flow of the Sort provides a skeletal view of the flow of control in the standard Disk Sort (including the incore sort), merge and copy. This chapter indicates the order in which the control statements and exit routines are processed, information which is particularly useful at the design stage of an application. MAXSORT explains when MAXSORT should be used, describes its JCL requirements, control statements and PARM options, and provide examples. The chapter also examines MAXSORTs restart capability and its operator interface. PARASORT explains the elapsed time advantages of the technique, the type of applications where it can be applied, and the JCL requirements. SyncSort DB2 Query Support explains how SyncSort can improve performance by allowing DB2 data to be passed directly into a SORT or COPY operation without the use of setup steps or user-written E15 exits. Tape Sort describes the SyncSort DD statements needed for a tape sort and how to initiate a tape sort from JCL or a program. Performance Considerations describes how to design the most efficient application. It contrasts the merits of Disk Sort, PARASORT, MAXSORT and Tape Sort, JCL and invoked sorts, the incore sort, and standard SORTWK techniques. Formulas for calculating main storage and SORTWK requirements are provided. Other topics include the efficient use of control statements and PARMs, tuning main storage and SORTWK allocations and the use of the Checkpoint-Restart feature. The HISTOGRM Utility Program describes how to use the HISTOGRM program to report on the composition of variable-length files. This program indicates the average record length, byte total, record total, block count and record count. Job control requirements, control statements and messages are outlined. Sample job streams illustrate how to run HISTOGRM as a separate job and as an E15 exit during a variable-length sort. Value-Added Products describes Visual SyncSort for z/OS, PROC SYNCSORT An Accelerator for SAS Sorting, and PipeSort. This chapter also provides detailed information regarding their functions and special features. Messages documents all of the WERnnnx messages generated by the SyncSort program. This chapter includes sections describing Troubleshooting with WER999A UNSUCCESSFUL SORT and What to Do Before Calling SyncSort for z/OS Product Services.

1.8

SyncSort for z/OS 1.2 Programmers Guide

Related Reading
The following guides supplement the information provided in the Programmers Guide. Installation Guide This manual explains how to install and maintain SyncSort and defines the default options. Reference Guide. This handbook, intended for quick reference, provides the syntax for SyncSort control statements and briefly describes each parameter. Exploiting SyncSort: SortWriter Data Utilities Guide. This two-part users guide demonstrates how SyncSorts versatile Data Utility features provide an efficient, one-step alternative to writing, testing and debugging programs. Five comprehensive sample applications illustrate how the control statements work together to produce formatted reports. Exploiting SyncSort: MAXSORT. This users guide explains how to use the special MAXSORT feature of SyncSort to sort very large amounts of data with only a limited amount of disk space. MAXSORTs unique restart capability is described and sample job control streams and tuning information are included.

Online Message Help


All SyncSort messages and their explanations can be accessed online through an ISPF/PDF dialog. Contact your system administrator for information about the operation of the message help facility.

Chapter 1. Introduction

1.9

1.10

SyncSort for z/OS 1.2 Programmers Guide

Chapter 2. SyncSort Control Statements

The control statements tell SyncSort for z/OS how to process files. There are 15 control statements: Control Statement ALTSEQ Function Specifies an alternate collating sequence for control fields with an AQ format. Signals the end of control statements. Specifies the criteria which determine whether or not records are included in an application. Reformats the input record before sort/merge processing. Specifies the disposition of paired and unpaired records in a join. Enables join feature processing and identifies the fields used to select records for join processing. Defines a merge or copy application and specifies merge control fields. Specifies user exit(s). Specifies the criteria which determine whether or not records are omitted from an application.

END INCLUDE

INREC JOIN JOINKEYS

MERGE

MODS OMIT

Chapter 2. SyncSort Control Statements

2.1

OUTFIL

Describes the output file(s) and specifies SortWriter and processing options. Reformats the output record after sort/merge processing. Provides record information at various processing stages. Defines the record layout to be produced by join processing. Defines a sort or copy application and specifies sort control fields. Deletes records with equal control fields and summarizes numeric fields on those records.

OUTREC RECORD REFORMAT SORT SUM

Control Statement Summary Chart


The following table summarizes the parameters of each control statement and indicates default values.

Control Statement Name ALTSEQ END INCLUDE

Parameters

Delivered Default

CODE=(ccpp 1 [,ccpp 2 ]...)

Standard EBCDIC series

ALL COND= (comparisons) [,FORMAT=f] NONE FIELDS=(field 1 [,field 2 ]...) UNPAIRED [,F1] [,F2] [,ONLY]

Sort/Merge all records

INREC JOIN

Input records unchanged Join only paired records

Table 1. (Page 1 of 6) Control Statement Summary Chart

2.2

SyncSort for z/OS 1.2 Programmers Guide

Control Statement Name JOINKEYS

Parameters

Delivered Default

F1 FILE= F2 FIELDS = ( p 1 ,l 1 ,o 1 [ ,p 2 ,l 2 ,o 2 ... ] ) [,SORTED] Presume records are unsorted Include all records from file in join processing

ALL NONE ,INCLUDE ,AND, ,OMIT = ,&, (c 1 c 2 ... ) ,OR, ,|, F ,TYPE= V MERGE FIELDS=(p ,l ,f ,o [,p ,l ,f ,o ]...) 1 1 1 1 2 2 2 2 FIELDS=(p 1 ,l 1 ,f 1 ,o 1 [,p 2 ,l 2 ,f 2 ,o 2 ]...),FORMAT=f FIELDS=COPY s ,CENTWIN= f ,CKPT ,CHKPT ,EQUALS ,NOEQUALS [ ,FILES=n ] [ ,SKIPREC=n ] [ ,STOPAFT=n ]

VSAM files are processed as fixed-length

Century window starts with current year No checkpoint NOEQUALS

Copy all records Copy all records

Table 1. (Page 2 of 6) Control Statement Summary Chart

Chapter 2. SyncSort Control Statements

2.3

Control Statement Name MODS

Parameters

Delivered Default

exit-name 1 =(r 1 ,b 1 [,d 1 ]

,N ,S ,C ),...,exit-name 16 =(...) ,E ,X ,T

No exits

OMIT

ALL COND= (comparisons) [,FORMAT=f] NONE [FILES=(fileid 1 [,fileid 2 ]...)] ddname ,FNAMES= (ddname 1 [,ddname 2 ]...) [,HEADER1=(field 1 [,field 2 ]...)] [,HEADER2=(field 1 [,field 2 ]...)] ,INCLUDE = ,OMIT ALL (comparisons) NONE

Sort/Merge all records

OUTFIL

One output file Output defined by FILES

No report heading No page headings Output all records

n ,LINES= ANSI (ANSI,n) [,NODETAIL]

60 (if report-writing parameters) Detailed report Produce a report with ANSI control characters Records are not repeated Return code of zero

[,REMOVECC]

[REPEAT=n] RC0 ,NULLOFL= RC4 RC16

Table 1. (Page 3 of 6) Control Statement Summary Chart

2.4

SyncSort for z/OS 1.2 Programmers Guide

Control Statement Name OUTFIL

Parameters

Delivered Default

[,STARTREC=n]

Start processing with first record End processing with last record All records are produced in output

[,ENDREC=n]

n ,SAMPLE= (n,m)

[,SAVE]

Omitted records not saved for output Record unchanged Record format unchanged Missing fields will be filled with blanks (x'40') when CONVERT option in use Output record format the same as input Retain all trailing bytes No split output No split output No sections No report trailer No page trailers

[OUTREC=(field 1 [,field 2 ]...)] [,CONVERT]

[,VLFILL=f]

[,FTOV]

[,VLTRIM=b] [,SPLIT] [,SPLITBY=n] [,SECTIONS=(field 1 [,field 2 ]...)] [,TRAILER1=(field 1 [,field 2 ]...)] [,TRAILER2=(field 1 [,field 2 ]...)]

Table 1. (Page 4 of 6) Control Statement Summary Chart

Chapter 2. SyncSort Control Statements

2.5

Control Statement Name OUTREC

Parameters

Delivered Default

[,FIELDS=(field 1 [,field 2 ]...)]

Record format unchanged Output record format the same as input

[,CONVERT]

RECORD

[TYPE=F|V] [,LENGTH=(l 1 ,...,l 7 )]

REFORMAT

FIELDS = ( Fn:p 1 ,l 1 [ ,[Fn:]p 2 ,l 2 ]... [ ,[Fn:]p m ] [ ,Fn:p n ] ) [,FILL=f]

SORT

FIELDS=(p ,l ,o [,p ,l ,o ]...) 1 1 1 2 2 2 FIELDS=(p 1 ,l 1 ,o 1 [,p 2 ,l 2 ,o 2 ]...),FORMAT=f FIELDS=COPY s ,CENTWIN= f ,CKPT ,CHKPT [,DYNALLOC=d/(d,n)/OFF] ,EQUALS ,NOEQUALS [,FILSZ=n] [,SIZE=n] [ ,SKIPREC=n ] [ ,STOPAFT=n ] Sort or copy all records Sort or copy all records Century window starts at current year No checkpoint No dynamic allocation NOEQUALS

Table 1. (Page 5 of 6) Control Statement Summary Chart

2.6

SyncSort for z/OS 1.2 Programmers Guide

Control Statement Name SUM

Parameters

Delivered Default

FIELDS=(p ,l ,f [,p ,l ,f ]...) 1 1 1 2 2 2 FIELDS=(p 1 ,l 1 [,p 2 ,l 2 ]...),FORMAT=f FIELDS=NONE [,XSUM]

No summary of fields; no reduction of equal-keyed records

Table 1. (Page 6 of 6) Control Statement Summary Chart

Chapter 2. SyncSort Control Statements

2.7

Disk Sort, MAXSORT, PARASORT, and Tape Sort Control Statement Requirements
The following table summarizes control statement usage for Disk Sort, MAXSORT, PARASORT, and Tape Sort. MAXSORT and PARASORT Optional Required for MAXSORT if exits included in input stream; optional for PARASORT Optional Optional Not supported Not supported Not applicable Required for exits

Control Statement ALTSEQ END

Disk Sort Optional Required if exits included in input stream

Tape Sort Not supported Required if exits included in input stream

INCLUDE/ OMIT INREC JOIN JOINKEYS MERGE MODS

Optional Optional Optional Optional Required for merge or copy Required for exits

Not supported Not supported Not supported Not supported Required for merge; copy not supported Required for exits; not supported if programinvoked Not supported

OUTFIL

Required for multiple output or reports Optional Conditionally required Optional Required for sort or copy Optional; not applicable to copy

Not supported for MAXSORT; optional for PARASORT Optional Conditionally required Not supported Required for sort; copy not supported Optional

OUTREC RECORD REFORMAT SORT SUM

Not supported Conditionally required Not supported Required for sort; copy not supported Not supported

Table 2.

Control Statement Usage for Disk Sort, MAXSORT, PARASORT, and Tape Sort

2.8

SyncSort for z/OS 1.2 Programmers Guide

Data Utility Processing Sequence


The following figure illustrates the sequence in which SyncSort control statements and parameters are processed. It includes those control statements and parameters that modify the input file (e.g., INCLUDE/OMIT), reposition record fields (e.g., INREC, OUTREC), and create reports (e.g., OUTFIL). When specifying record fields on any of these SyncSort control statements or parameters, refer to the record as it appears at that stage of SyncSort processing. For example, when specifying SORT fields be sure to take into account any repositioning of fields that may be due to INREC processing.

Chapter 2. SyncSort Control Statements

2.9

Input File

Input File 1

Input File 2

Record Selection for Join File 1 JOINKEYS INCLUDE/OMIT Parameter

Record Selection for Join File 2 JOINKEYS INCLUDE/OMIT Parameter

Join Processing JOIN, JOINKEYS, REFORMAT Control Statements Conventional SORTIN Sort Processing Record Selection INCLUDE/OMIT Control Statement

SORTJNF1, SORTJNF2 Join Processing

Field Selection INREC Control Statement

Record Arrangement SORT Control Statement

Combining/Eliminating Duplicate Records SUM Control Statement

Printable and Easy to Read Output and Variable to Fixed Length Format Conversion OUTREC Control Statement

Record Selection for Output File 1 STARTREC, ENDREC, INCLUDE/OMIT, SAVE Parameters

Record Selection for Output File n STARTREC, ENDREC, INCLUDE/OMIT, SAVE Parameters

Report Formatting for Output File 1

Report Formatting for Output File n

Printable & Easy to Read Output for File 1 & Variable to Fixed Length Format Conversion or Fixed to Variable Format Conversion OUTREC, CONVERT, FTOV Parameters

Printable & Easy to Read Output for File 1 & Variable to Fixed Length Format Conversion or Fixed to Variable Format Conversion OUTREC, CONVERT, FTOV Parameters

Output File 1

Multiple Output and Report Formatting OUTFIL Control Statement(s)

Output File n

Figure 2. Data Utility Processing Sequence

2.10

SyncSort for z/OS 1.2 Programmers Guide

Control Statement Examples


Simple examples illustrating the syntax of each of the SyncSort for z/OS control statements are included in this chapter. More complex applications are presented in Chapter 3.How to Use SyncSorts Data Utility Features. These applications demonstrate how the INCLUDE/ OMIT, INREC, JOIN, JOINKEYS, OUTFIL, OUTREC, REFORMAT, and SUM control statements can be used to accomplish a variety of tasks, such as selecting input records, selecting input fields, joining records with matching keys, combining records, reformatting output records, writing reports, and creating multiple output.

Rules for Control Statements


The following rules apply to SyncSort for z/OS control statements.

Specifying Control Statements


Control statements can be in any order, except for the END control statement which, if specified, must be last. Each control statement, except for JOINKEYS and OUTFIL, can be specified only once for a particular application. The control statement can begin in column 2 through column 69. If labels are used, the control statement must be separated from the label by at least one blank. The control statement name must be the first field (or the first field after a label) of the first card image of the control statement. It cannot be continued on a continuation card image. The last operand of each control statement must be followed by at least one blank.

Specifying Parameters
Parameters can take three forms: Parameter Parameter=value Parameter=(value) Parameter(value) Parameter=(value1,value2,...,valuen) Parameter(value1,value2,...,valuen) Note that multiple values must be enclosed in parentheses.

Chapter 2. SyncSort Control Statements

2.11

Parameters can be in any order, but if parameters are present, the first parameter must begin on the first card image of a control statement. Parameters must be separated from each other by commas. The parameter(s) must be preceded and followed by at least one blank. A blank separates the parameter(s) from the control statement name and also indicates the end of the control statement. If the parameter(s) end in column 71, column 72 must contain a blank to signal the end of the control statement. With the exception of literal strings and constants, a parameter value cannot exceed 28 alphanumeric characters. Parameter values cannot include commas, equal signs, or parentheses. With the exception of literal strings specified as parameter values, blanks are not permitted within parameters.

Specifying Field Positions, Lengths, and Formats


Control statements reference fields by position p and length l. The first byte of every fixed-length record is position 1, the second byte position 2, and so on. Bytes 1 through 4 of variable-length records are reserved for the Record Descriptor Word (RDW). For these records, the first byte of the data portion is position 5. Some control statements support bit-level processing. This means a binary control field can begin and end on any bit of any byte. The 8 bits in each byte are numbered 0 through 7. For example, a position value of 7.4 designates a field beginning on the fifth bit of the seventh byte. A length value of 7.4 designates a field 7 bytes, 4 bits long. Make sure the position value takes into account any record reformatting and data conversion that may have resulted from SyncSort data utility processing or exit programs. Refer to the Data Utility Processing Sequence figure at the beginning of this chapter and to Chapter 8.The Flow of the Sort. When proper processing depends on data format, the format of the field must be specified. The format of the field must be appropriate to the task. For example, only numeric fields can be SUMmed. When all the fields have the same format, the format value can be specified just once through the FORMAT=f subparameter. The FORMAT=f subparameter cannot be used when the INCLUDE/OMIT parameter is specified on the OUTFIL control statement.

2.12

SyncSort for z/OS 1.2 Programmers Guide

Specifying Comments
Identify a comment card image by placing an asterisk (*) in column 1. Comments can extend through column 80. To add a comment to a control statement card image, leave one or more blanks after the last parameter or comma on the image and follow with the comment, which can extend through column 71. Continue a comment that follows a control statement by coding an asterisk (*) in column 1 of the next card image or, if the control statement had ended, by placing a continuation character in column 72. Comment lines can be inserted between a control statement and its continuation by coding an asterisk (*) in column one.

Specifying Continuation Card Images


Control statements cannot extend beyond column 71, but they can be continued. To continue a control statement: Break after a parameter-comma or parameter-colon combination before column 72. Begin the continuation of the next card image anywhere between columns 2 and 71 if there is no label on the continuation card. If there is a label, begin the continuation card in any column from 3-71. No continuation character is required. --or- When the control statement extends through column 71 and cannot be broken at a parameter-comma or parameter-colon combination: If the control statement does not contain a literal string that would extend beyond column 71, place a continuation character in column 72 and continue the control statement on the next card image anywhere between columns 2 and 71. If the control statement does contain a literal string that would extend beyond column 71, place a continuation character in column 72 and begin the continuation of the literal string in column 16 of the next card image.

The following examples illustrate how card images can be continued.

COL. 72 SORT FIELDS=(1,10,A,20,5,A,45,7,A),FORMAT=CH,STOPAFT=100, EQUALS Figure 3. Continuing a Control Statement Without Specifying a Continuation Character

Chapter 2. SyncSort Control Statements

2.13

In the above example, no continuation character is required. The control statement is interrupted after a parameter-comma combination before column 72.

COL. 16 COL.72 OUTFIL OUTREC=(1:10,8,30:40,10),HEADER2=(1:'CUSTOMER NUMBX ER',30:'ITEM NUMBER')

Figure 4. Continuing a Control Statement with a Continuation Character In this example, a continuation character is necessary because the literal string in the HEADER2 specification would extend beyond column 71. The 'X' in column 72 is the continuation character. The literal string is continued in column 16 of the next card image.

Specifying Labels
SyncSort for z/OS supports labels. If labels are used, the following rules apply: Labels are permitted on all SYSIN control statements, including continuation card images, but not on the control statements passed by an invoking program or the $ORTPARM DD statement. Labels must begin in column 1 with an alphabetic character. Labels can be any length, provided the other rules which apply to control statements are followed. At least one blank must separate the label from the control statement name or parameter that follows it.

Notational Conventions Used in the SyncSort for z/OS Programmers Guide


Braces indicate that a choice must be made from the alternatives listed. Brackets indicate an optional item. Two or more items in brackets are mutually exclusive options; only one can be chosen for a particular application. Defaults are underlined. Upper-case letters, numbers, commas, equal signs, and parentheses must be entered exactly as indicated. Lower-case letters represent variables which must be replaced by actual values. Subscripts show position in a series, and three dots indicate an ellipsis. For example, a1,a2,...,a5 is equivalent to a1,a2,a3,a4,a5 and represents five a items (variables which will be replaced with actual values).

2.14

SyncSort for z/OS 1.2 Programmers Guide

Examples that are to be entered exactly as shown are presented in the Courier typeface, for instance:

ALTSEQ CODE=(F0B7,F1B8,F2B9,F3BA,F4BB,F5BC,F6BD,F7BE,F8BF,F9C0) Figure 5. Examples

Chapter 2. SyncSort Control Statements

2.15

ALTSEQ ALTSEQ Control Statement


The ALTSEQ control statement constructs an alternate collating sequence for all control fields for which the format code AQ has been specified on the SORT/MERGE control statement, and/or an INCLUDE/OMIT control statement, and/or an INCLUDE/OMIT parameter of the OUTFIL control statement. If an alternate collating sequence has been provided by installation default, AQ fields collate against this sequence, modified by the ALTSEQ control statement. If a default alternate sequence has not been provided, AQ fields collate against the standard EBCDIC sequence, modified by the ALTSEQ control statement. AQ can be specified for one or more control fields so that those control fields all use the same alternate collating sequence. The ALTSEQ control statement also constructs an alternate collating sequence for all control fields processed by the TRAN parameter of the INREC and OUTREC control statements, as well as the TRAN subparameter of the OUTREC parameter on the OUTFIL control statement. The ALTSEQ control statement cannot be specified for a Tape Sort.

ALTSEQ Control Statement Format


The format of the ALTSEQ control statement is illustrated below:

ALTSEQ CODE=(ccpp1 [,ccpp2]...) Figure 6. ALTSEQ Control Statement Format

CODE Parameter (Required)


The CODE parameter specifies how the characters of the current collating sequence are to be reordered to create the alternate collating sequence. The CODE parameter can contain from 1 to 256 entries, each consisting of four hexadecimal digits. These entries must be separated by commas and enclosed in parentheses. Each CODE entry consists of two parts: cc The cc value represents the character that is to be repositioned in the alternate sequence. The pp value indicates where the character represented by the cc value is to be repositioned in the alternate sequence.

pp

The character represented by the cc value does not replace the character represented by the pp value. If both characters occur as sort control fields, they will be considered equal in the collating process.

2.16

SyncSort for z/OS 1.2 Programmers Guide

ALTSEQ
Each character (cc entry) can be moved only one time. However, more than one cc entry can be mapped to the same pp value.

Sample ALTSEQ Control Statements


ALTSEQ CODE=(F0B7,F1B8,F2B9,F3BA,F4BB,F5BC,F6BD,F7BE,F8BF,F9C0) Figure 7. Sample ALTSEQ Control Statement This sample ALTSEQ control statement shows that the numbers 0 through 9 are to collate before the uppercase alphabet.

ALTSEQ CODE=(F040) Figure 8. Sample ALTSEQ Control Statement This sample ALTSEQ control statement specifies that the number 0 is to collate as equal to a blank (X'40').

Chapter 2. SyncSort Control Statements

2.17

END END Control Statement


If present, the END control statement must be the last control statement. The END control statement is required only when the control statements are not followed by /* or by a job control statement (i.e., when including exits in the input stream). The END control statement has no parameters, but can contain comments if the comments are preceded by at least one blank.

2.18

SyncSort for z/OS 1.2 Programmers Guide

INCLUDE/OMIT INCLUDE/OMIT Control Statement


The INCLUDE/OMIT control statement selects records from an input file based on comparisons testing the contents of one or more fields within the record. A field can be compared to a constant or to another field within the record. Furthermore, a binary field may enter into comparisons that involve testing the individual bits in the field. Only one INCLUDE/OMIT control statement can be specified for an application, either as an INCLUDE or as an OMIT control statement.

Locale-Based Comparison Processing


SyncSort supports alternative sets of collating rules based on a specified national language. The alternative collating applies to INCLUDE/OMIT (and OUTFIL INCLUDE/OMIT) comparison processing as well as to SORT/MERGE processing. A locale defines single and multi-character collating rules for a cultural environment. Locale-based INCLUDE/OMIT processing applies only to character (CH) fields and character or hexadecimal constants compared to character fields. When LOCALE is active, a CH to BI (or BI to CH) comparison is not allowed. The illegal comparison will cause SyncSort to terminate with an error message. For more information on locale-based processing, see LOCALE on page 5.19.

INCLUDE/OMIT Control Statement Format


The format of the INCLUDE/OMIT control statement follows.

Chapter 2. SyncSort Control Statements

2.19

INCLUDE/OMIT

ALL NONE INCLUDE ,AND, COND= ,&, OMIT (c 1 c 2 ... ) [,FORMAT=f] ,OR, ,|, c represents a comparison. Each comparison has this format: ,EQ, ,NE, ,GT, p 2 ,l 2 [,f 2 ] [,f 1 ] ,GE, constant ,LT, ,LE, ,BO, ,ALL, ,BM, ,SOME, ,BZ, ,NONE, p 1 ,l 1 , bit mask ,BNO, ,BI ,NOTALL, ,BNM, ,NOTSOME, ,BNZ, ,NOTNONE, ,EQ, bit pattern ,NE, ,SS ,EQ, constant ,NE,

Figure 9. INCLUDE/OMIT Control Statement Format

COND Parameter (Required)


The COND parameter controls how records are included or omitted from an application. There are three forms of the COND parameter: COND=ALL All of the input records are to be included. This is the default.

2.20

SyncSort for z/OS 1.2 Programmers Guide

INCLUDE/OMIT
COND=NONE COND=comparison(s) None of the input records are to be included. Specifies one or more comparisons that determine which records are to be included or omitted. Two types of comparisons are possible: A standard comparison, between two record fields or between a record field and a constant. A binary input field also allows comparison by bit mask or bit pattern. A substring comparison, which allows the search for a constant within a field or for a field value within a constant. Use SS as the format to indicate a substring comparison.

The following several pages describe standard comparisons. For information on substring comparisons, see Full-Date Comparisons on page 2.33. Each field specified in the COND parameter is identified by its position (p), length (l) and format (f). When processing variable-length records, by default all fields specified must be contained within the record. If an application is expected to reference fields not completely contained within the record, refer to VLTESTI on page 5.32. VLTESTI provides for processing of records that do not contain all fields. p The position value indicates the first byte of the field relative to the beginning of the input record after E15 or E32 processing, if specified, has completed. The field must begin on a byte boundary. (Keep in mind that if a variable-length file is being referenced, the first 4 bytes must be reserved for the Record Descriptor Word.) The length value indicates the length of the field. The length must be an integer number of bytes. See the table below for permissible field lengths by format. The format value indicates the format of the field. The permissible formats for standard comparisons are indicated in the following table. If all data fields have the same format, the FORMAT=f subparameter can be specified instead of the individual f values. If both are specified, the individual f values will be used for fields where they are specified.

Chapter 2. SyncSort Control Statements

2.21

INCLUDE/OMIT

Data Format AC AQ ASL AST BI CH CLO/OL CSF/FS CSL/LS CST/TS CTO/OT FI PD PD0 Y2B Y2C/Y2Z Y2D Y2P Y2S Y2T, Y2U, Y2V, Y2W, Y2X, Y2Y ZD Table 3.

Acceptable Field Length (Bytes) 1 to 256 1 to 256 2 to 256 2 to 256 1 to 256 1 to 256 1 to 256 1 to 16 2 to 256 2 to 256 1 to 256 1 to 256 1 to 256 2-8 1 2 1 2 2 2-6 1 to 256

Valid Formats and Lengths of Include/Omit Fields

For definitions of the field format, see Valid Formats for Merge Control Fields on page 2.47. The constant to which a field can be compared may be one of the following types:

2.22

SyncSort for z/OS 1.2 Programmers Guide

INCLUDE/OMIT
decimal A decimal constant can be any length. It should not be enclosed in single quotes. It may or may not include a leading + or - sign. For example, 100 is a valid decimal constant. The following numeric data compare as equal: +0, -0, 0. The &DATExP date parameter represents the current date as a decimal number (+n) to which a field can be compared. See page 2.30 for more details. A hexadecimal constant should be preceded by an X and specified in pairs of valid hexadecimal values which must be enclosed in single quotes: X'hh...hh'. For example, X'ACBF05' is a valid hexadecimal constant. The sign of the field is implicit in the representation. A character constant should be preceded by a C and enclosed in single quotes: C'literal'. For example, C'SALES' is a valid character constant. The &DATEx and &DATEx(c) date parameters represent the current date as a character string (C'string') to which a field can be compared. See page 2.30 for more details. You can also include or omit records based on whether their dates fall within a specified time frame before or after the current date. See page 2.32 for more details. To include an apostrophe in a character constant, specify it as two apostrophes; for example, C'D''AGOSTINO'. If a character constant must be continued on a second card image, place a continuation character in column 72 and then begin the continuation of the constant in column 16 of the next card image. There are two methods in which the bit level characteristics of a binary input field can be used to include or omit records. One is to compare the binary field to a bit mask; the other is to compare the binary field to a bit pattern. bit mask A bit mask is a string of bits, specified in terms of either hexadecimal or binary digits. The bit mask indicates which bits in the input field are to be tested. Each bit in the mask whose value is 1 (ON) is tested against the corresponding bit in the input field. If the value of a mask bit is 0 (OFF), the corresponding bit in the input field is ignored. The hexadecimal format of a bit mask is X'hh...hh,' where each 'hh' represents any pair of hexadecimal digits. The binary format of a bit mask is B'bbbbbbbb...bbbbbbbb', where each 'bbbbbbbb' represents 8 bits or a byte. Each bit is 1 or 0. The number of bits in a binary bit mask must be a multiple of 8. The maximum length of a binary bit mask is 256 bytes (2048 bits).

hexadecimal

character

Chapter 2. SyncSort Control Statements

2.23

INCLUDE/OMIT
A bit mask is truncated or padded on the right to the byte length of the binary field. The pad character is X'00' or B'00000000'. bit pattern The binary format of a bit pattern is B'bbbbbbbb...bbbbbbbb', where each 'bbbbbbbb' represents 8 bits or a byte. Each bit is 1, 0, or period (.). If the value of a bit in the bit pattern is 1 or 0, the corresponding bit in the binary input field is compared to 1 or 0. If . (period) occurs in a bit position in the bit pattern, the corresponding bit in the input field is ignored. The number of bit positions in a bit pattern must be a multiple of 8. The maximum length of a bit pattern is 256 bytes (2048 bits). A bit pattern is truncated or padded rightward to the byte length of the binary input field. The pad character is B'00000000'. The comparison operators represent the following conditions: EQ NE GT GE LT LE BO (or ALL) BM (SOME) BZ (NONE) BNO (NOTALL) BNM (NOTSOME) BNZ (NOTNONE) Equal to Not equal to Greater than Greater than or equal to Less than Less than or equal to All mask bits are 1s (ON) in the input field Some but not all mask bits are 1s (ON) in the input field None of the mask bits is 1 (ON) in the input field Some or no mask bits are 1s (ON) in the input field All or no mask bits are 1s (ON) in the input field All or some mask bits are 1s (ON) in the input field

Rules for Multiple Comparisons Multiple comparisons are separated by ANDs or ORs to form a logical expression. (Alternatively, & and | may be used for AND and OR). When evaluating an expression, each comparison cn is evaluated first. Then, AND conditions are evaluated before OR conditions.

2.24

SyncSort for z/OS 1.2 Programmers Guide

INCLUDE/OMIT
Parentheses may be used around groups of comparisons to change the default evaluation order. Any number of nested parentheses may be used. Conditions within parentheses are evaluated first, from innermost to outermost parentheses. For example, if you wanted to select all records from your Paris office for 1995 and 1996, you might incorrectly specify: INCLUDE COND=(1,4,CH,EQ,C'1995',OR,1,4,CH,EQ,C'1996', AND,5,5,CH,EQ,C'PARIS') The AND operator in the above statement would be evaluated first, producing unexpected output. The correct statement would be: INCLUDE COND=((1,4,CH,EQ,C'1995',OR,1,4,CH,EQ,C'1996'), AND,5,5,CH,EQ,C'PARIS') The added parentheses force the OR operator to be evaluated first, thus producing the expected output. Specifying Field-to-Field Standard Comparisons for Non-date Fields The format of a data field determines whether or not it can be compared to another data field. The figure below illustrates which field-to-field comparisons are permitted.

Chapter 2. SyncSort Control Statements

2.25

INCLUDE/OMIT

AC AC AQ ASL AST BI CH CLO OL CSF FS CSL LS CST TS CTO OT FI PD PD0 ZD X

AQ

ASL AST

BI

CH

CLO CSF CSL CST CTO OL FS LS TS OT

FI

PD

PD0

ZD

X X X X X X X X X X X X X X X X X X X X X X X X X Table 4. Permissible Field-to-Field Comparisons for Non-year Data Formats X X X

Padding of Compared Fields When two fields are compared, the shorter field is padded to the length of the longer field. Padding takes place as follows: The padding characters are blanks when the shorter field is in character format; otherwise, they are zeros of the shorter fields own format. Padding is on the right if the shorter field is in BI, CH or PD0 formats. Padding is on the left for all other formats.

2.26

SyncSort for z/OS 1.2 Programmers Guide

INCLUDE/OMIT
Specifying Field-to-Field Standard Comparisons for Year Fields The year data formats that can be used with INCLUDE/OMIT are Y2B, Y2C, Y2D, Y2P, Y2S and Y2Z. Year data formats can only be compared to other year formats; they cannot be compared to formats in the table above. The full date formats that can be used with INCLUDE/OMIT are Y2T, Y2U, Y2V, Y2W, Y2X, and Y2Y. The full date formats may only be compared to other 2-digit year full date formats with the same number of non-year digits. The year data formats work with the CENTWIN run-time parameter or installation option to define a 2-digit year value that is to be treated as a 4-digit year. CENTWIN defines a sliding or fixed 100-year window that determines the century to which 2-digit year data belong when processed by INCLUDE/OMIT and other control statements. The year data formats and CENTWIN ensure that century evaluation is applied to INCLUDE/OMIT comparison conditions involving 2-digit year data. For example, without CENTWIN processing, an INCLUDE/OMIT comparison would treat the year 01 as "less than" the year 98. With CENTWIN processing, the 01 field could be recognized as a twentyfirst century date (2001), which would be treated as "greater than" 98 (1998). For details on the CENTWIN option, see CENTWIN on page 5.7. For details on the year data formats, see CENTWIN Parameter (Optional) on page 2.149. For an example of an INCLUDE control statement with a condition involving a year data field, see Figure 16 on page 2.36.

Chapter 2. SyncSort Control Statements

2.27

INCLUDE/OMIT
For any of the 2-digit year formats, it is valid to compare them with any of the other formats. Specifically, Y2B, Y2C, Y2D, Y2P, Y2S, and Y2Z fields can be compared to each other. The following table summarizes the valid field to field comparisons for Full-Date formats:

Date Form yyx and xyy 3,Y2T 3,Y2W 2,Y2U 2,Y2X 4,Y2T 4,Y2W 3,Y2V 3,Y2Y 5,Y2T 5,Y2W 3,Y2U 3,Y2X 6,Y2T 6,Y2W 4,Y2V 4,Y2Y

Length and Data Format Allowed

yyxx and xxyy

yyxxx and xxxyy

yyxxxx and xxxxyy

Table 5. Permissable Field-to-Field Comparisons for Full-Date Formats

2.28

SyncSort for z/OS 1.2 Programmers Guide

INCLUDE/OMIT
Specifying Field-to-Constant Standard Comparisons The format of a data field determines the type of constant to which it can be compared. The figure below illustrates which field-to-constant comparisons are permitted.

Format AC AQ ASL AST BI CH CLO / OL CSF / FS CSL / LS CST / TS CTO / OT FI PD PD0 Y2B Y2C/Y2Z Y2D Y2P Y2S Y2T*** Y2U*** Y2V***

Decimal

Hexadecimal X X

Character X X

Binary (bit pattern)

Year Constant

X X X* X X X X X X X X** X X X X X X X X X X Table 6. (Page 1 of 2) Permissible Field-to-Constant Comparisons X X X X X X X X X X X

Chapter 2. SyncSort Control Statements

2.29

INCLUDE/OMIT
Format Y2W*** Y2X*** Y2Y*** ZD Decimal X X X X Hexadecimal Character Binary (bit pattern) Year Constant X X X

Notes: * The decimal constant cannot be higher than 4294967295 or lower than 0. ** The decimal constant cannot be higher than 2147483647 or lower than -2147483648. *** Full-Date formats Table 6. (Page 2 of 2) Permissible Field-to-Constant Comparisons A constant will be padded or truncated to the length of the field with which it is compared. Decimal constants are padded or truncated on the left; hexadecimal, binary, and character constants are padded on the right. The padding characters are: Binary string Character string Hexadecimal string Decimal fields B'00000000' X'40' X'00' Zeros of proper format. Decimal constants for 2-digit year formats are padded or truncated to two decimal digits representing a year. The year constant will then have CENTWIN processing applied to it for comparison to a Y2 field. These are only for the two digit year fields, not for full date constants.

The constants for PD0 comparison should not include the first digit and trailing sign of the PD0 data that will be ignored. Thus, a PD0 field of n bytes will be compared to a constant of n-1 bytes.

Current Date Constant Specification


You can compare fields to the date of a SyncSort run or the date of the run with an offset in addition to decimal fields and binary, character, and hexadecimal strings. Thus, records can more easily be included or omitted based on whether their dates are equal to, less than, or greater than the run date or the run date with an offset.

2.30

SyncSort for z/OS 1.2 Programmers Guide

INCLUDE/OMIT
The format of a current date constant is: + current date constant nnnn -

where: current date constant is in the form of one of the &DATEx, &DATEx(c), &DATExP, or Y'DATEx' parameters where x is 1, 2, 3, or 4 and depends on date comparison compatibility. + indicates a date after the current date, and - indicates a date before the current date. nnnn can have a maximum of 15 digits with the leftmost zeroes truncated. When the x in &DATEx, &DATEx(c), &DATExP, or Y'DATEx' is 1, 3, or 4, nnnn can be from 09999 and represents offset days. When the x in &DATEx, &DATEx(c), &DATExP, or Y'DATEx' is 2, nnnn can be from 0-999 and represents offset months.

For an example of an INCLUDE control statement that uses a date range based on a date constant, see Figure 17 on page 2.37. The forms of current date constants available for standard comparisons are: &DATEx and &DATEx(c) represent the current date as a character string (C'string') to which a field can be compared. &DATExP represents the current date as a decimal number (+n) to which a field can be compared. Y'DATEx' represents the current date with a Y constant (Y'string') to which a field can be compared.

The following table shows the current date constants and the format produced by each. The c character in &DATEx(c) represents a non-blank separator character, except open and close parentheses.

Chapter 2. SyncSort Control Statements

2.31

INCLUDE/OMIT

Current Date Constant &DATE1 &DATE1(c) &DATE1P &DATE2 &DATE2(c) &DATE2P &DATE3 &DATE3(c) &DATE3P &DATE4 Y'DATE1' Y'DATE2' Y'DATE3'

Generated Constant C'yyyymmdd' C'yyyycmmcdd' +yyyymmdd C'yyyymm' C'yyyycmm' +yyyymm C'yyyyddd' C'yyyycddd' +yyyyddd C'yyyy-mm-dd-hh.mm.ss' Y'yymmdd' Y'yymm' Y'yyddd'

Table 7. Current Date Constant Formats

Full-Date Format Constant Specifications


Constants used for full-date comparisons should have the same number of digits in the constant as in the full-date field that has been specified. Leading zeros must be specified when needed. The constant is constructed from two items; the first is a 2-digit year and the second is a value representing the months or days that comprise the remainder of the full date format. For example, if a 5-byte Y2W field were to be compared for a value greater than the 20th day of 1996, 96020 should be the code for the constant. Constants can be coded to represent special values, such as those found in header or trailer records. All zeros or nines may be used with Y2T, Y2U, Y2V, Y2W, Y2X, and Y2Y. The same number of digits must be present as in the field that is being compared. The constant string Y'LOW' (representing binary zeros), Y'HIGH' (representing binary ones), or Y'BLANKS' (representing blanks) may be coded with the fields Y2T, Y2W, and Y2S. Y'DATEx' (representing the current date) may be coded with certain full-date formats specifically (see Table 8).

2.32

SyncSort for z/OS 1.2 Programmers Guide

INCLUDE/OMIT

Y Constant Y'DATE1'

Date Form

Length and Data Format Allowed

yyxxxx and xxxxyy 6,Y2T 6,Y2W 4,Y2V 4,Y2Y yyxx and xxyy 4,Y2T 4,Y2W 3,Y2V 3,Y2Y 5,Y2T 5,Y2W 3,Y2U 3,Y2X

Y'DATE2'

Y'DATE3'

yyxxx and xxxyy

Table 8. Full-Date Comparisons

Substring Comparisons
Substring comparison (SS format) can be based on either of the following searches: Match occurrence of a constant within a record field Match occurrence of a record field within a constant.

In the first form, the length of the constant is less than the length of a specified field. Records will be searched for the occurrence of the constant anywhere within the field. The condition will be true if an EQ operator is specified and the constant is found or if a NE operator was specified and the constant is not found. For example, consider the constant ANYTOWN and a 60-byte field that contains an address. Records will be searched for the occurrence of the literal ANYTOWN anywhere within the 60-byte address field. If a match is found and the logical operator is EQ, then the logical result is true. The logical result is also true if the literal does not appear within the 60 bytes and the logical operator is NE. In the second form, the length of a constant is greater than the length of a specified field. Records will be searched for an occurrence of the field within the constant. For example, the constant 'A02,A05,A06,A09', which is composed of substrings separated by commas, can be compared against the contents of a 3-byte field within the record. If the 3-byte field matches any 3-byte character string in the constant, the logical result is true if the logical operator is EQ. The character used to separate elements of the constant should be a character that does not appear in the field being compared. The comparison is then equivalent to a standard comparison with ORed conditions. That is, the condition is true if 'A02' OR 'A05' OR 'A06' OR

Chapter 2. SyncSort Control Statements

2.33

INCLUDE/OMIT
'A09' is found in the field being compared. The substring comparison is a much more compact expression than multiple OR conditions in a standard comparison. For both forms of substring comparison, fields in the record can be from 1 to 32752 bytes in length. Constants can be in either character or hexadecimal format and can be from 1 to 256 bytes in length. (See the description of constants just after Table 6 on page 2.29.) See Figure 15 on page 2.36 for an example of how to use the substring comparison.

Sample INCLUDE/OMIT Control Statements


Example 1

INCLUDE COND=(24,4,PD,LT,28,4,PD,OR,10,2,CH,EQ,C'NY') Figure 10. Sample INCLUDE Control Statement In this example, records will be included in the application if the numeric value in the field beginning in byte 24 is less than the numeric value in the field beginning in byte 28 or if the character value in the field beginning in byte 10 is equal to NY. Example 2

OMIT COND=(1,3,ZD,EQ,100,AND,20,1,CH,NE,X'40') Figure 11. Sample OMIT Control Statement In this example, records will be omitted from the application if the numeric value in the field beginning in byte 1 is equal to 100 and if the character value in byte 20 is not equal to a blank (X'40'). The next set of control statements exemplifies record selection using bit level logic. The first two examples involve a comparison between a bit mask (shown coded in binary and hexadecimal format) and a binary input field. The third example is a comparison between a bit pattern and a binary field. Example 3

INCLUDE COND=(10,1,BI,ALL,B'01001000') or INCLUDE COND=(10,1,BI,ALL,X'48') Figure 12. Sample INCLUDE Control Statement Using a Bit Mask The record selection condition has the following elements (from left to right): a binary field (BI) of length 1 byte that starts at column 10 of the record, a comparison operator (ALL), and a bit mask (B'01001000' in binary, X'48' in hexadecimal). Counting from the left, the

2.34

SyncSort for z/OS 1.2 Programmers Guide

INCLUDE/OMIT
second and fifth bits of the bit mask are ON (1). For the selection condition to be true, the same bits must be ON in the binary input field. Therefore, if the input field contains, for example, 01001000, 01111000 or 11111111, the condition for the inclusion of records is satisfied. However, if the input field contains a bit string where both mask bits are not ON (e.g., 01000000, in which the fifth bit is not ON), the condition fails and the records are omitted. Example 4

INCLUDE COND=(10,1,BI,NOTNONE,B'01001000') or INCLUDE COND=(10,1,BI,NOTNONE,X'48') Figure 13. Sample INCLUDE Control Statement Using a Bit Mask The condition for the inclusion of records is met if at least one of the mask bits is ON in the input field. Therefore, the condition would evaluate as true, if the bit string in the binary field were 01000000 (the second bit is ON), 000010000 (the fifth bit is ON), 01001000 (both the second and fifth bit are ON). However, with the string 10000111, for instance, in the input field, the specified condition would evaluate as false (resulting in the omission of records), since neither mask bit is ON. The above method of comparing a binary input field to a bit mask is useful for testing the contents of a "flag" byte where each bit has a different meaning. Example 5

INCLUDE COND=(21,4,BI,EQ,B'000000010001........100100011111') Figure 14. Sample INCLUDE Control Statement Using a Bit Pattern The condition specifies a 4-byte long binary input field (BI) in column 21, a logical relationship (EQ), and a bit pattern. The bit pattern describes the required sequence of 1s and 0s in the first and last twelve bit positions. The row of periods in the pattern represents the part of the string that is irrelevant to the definition of the condition. The condition is true, if the sequence of 1s and 0s in the input field is identical to that described in the bit pattern. The method of comparing a binary input field to a bit pattern is useful when testing for numeric digits that are one half byte each, as in the packed data format. For example, assume that the binary input field specified in the condition above is a date field in the PD format X'0mmddyyF'. Each date element is split across a byte boundary. The second halfbyte of each byte (except the last) represents the first of the two digits that form a date element (mm,dd,yy). (In the last byte, the second half-byte--1111 in binary and F in hexadecimal--stands for the fact that the bit pattern encodes a packed decimal.) The first half-byte of each byte (except the first) represents the second digit of a date element (mm,dd,yy). (The first half-byte, i.e. 0000, of the bit pattern gives it the length specified for the binary

Chapter 2. SyncSort Control Statements

2.35

INCLUDE/OMIT
field at column 21.) Mapping this scheme onto the bit pattern in the control statement results in the following.

That is, the above control statement is an instruction to select just those records in whose date field mm and yy equal 11 and 91, respectively, while dd can have any value. In other words, the records thus selected are those from November 1991. Example 6 The following example illustrates substring comparisons.

INCLUDE COND=(11,60,EQ,C'ANYTOWN', OR,121,3,EQ,C'A01,A05,A06,A09'),FORMAT=SS Figure 15. Sample INCLUDE Control Statement Using Substring Compares In this example, a record will be included in the application if either of the following conditions is true: The literal 'ANYTOWN' is found in the 60-byte field starting at position 11 in the record. The contents of the 3-byte field starting at position 121 matches one of the four substrings ('A01', 'A05', 'A06', or 'A09') in the constant.

Example 7 The following example illustrates an INCLUDE comparison based on CENTWIN processing.

INCLUDE COND=(20,2,Y2C,GT,96) Figure 16. Sample INCLUDE Control Statement with CENTWIN Processing

2.36

SyncSort for z/OS 1.2 Programmers Guide

INCLUDE/OMIT
In this example only records whose data are from the years greater than 1996 will be included in the application. If the CENTWIN parameter were set to 1980, representing a century window of 1980 to 2079, the records would be processed in the following manner: Contents of Positions 20 and 21 84 99 37 Example 8 The following INCLUDE control statement illustrates the use of the current date constant and the current date with an offset to include records with dates starting with the current date and spanning through the two week period prior to the current date. INCLUDE COND=(5,8,ZD,LE,&DATE1P,AND,5,8,ZD,GT,&DATE1P-14) Figure 17. Sample INCLUDE Control Statement Using Current Date Constant and Current Date Constant With an Offset Comparison If the application were run on April 25, 2002, the records included would have dates in the 8-bytes field starting at position 5 from April 12, 2002 through and including April 25, 2002. Applications using the INCLUDE/OMIT control statement are illustrated in Chapter 3.How to Use SyncSorts Data Utility Features. Record Disposition Omitted - represents 1984 Included - represents 1999 Included - represents 2037

Chapter 2. SyncSort Control Statements

2.37

INREC INREC Control Statement


The INREC control statement reformats the input records. Use the INREC control statement to add, delete, or reformat fields before the records are sorted or merged. Use the OUTREC control statement or the OUTREC parameter of the OUTFIL control statement to delete or reformat fields after the records are sorted or merged. Note that INREC is performed after E15 exit processing and INCLUDE/OMIT control statement processing. Using the INREC control statement to delete data fields improves sort performance by reducing the number of bytes SyncSort for z/OS must process. The same result may be achieved in some cases by changing the data format of certain fields. For example, if you need to change the format of a ZD field to PD, which reduces the number of bytes for the field, it is more efficient to use INREC rather than OUTREC for the conversion. Additionally, for SORT/MERGE processing PD fields are processed more efficiently than ZD fields. Except for CONVERT, all the functions performed by the OUTREC control statement, such as inserting character strings or changing the data format of a numeric field, can also be performed by the INREC control statement. (See OUTREC Control Statement on page 2.97 for an explanation of these functions.) For example, you can use the INREC control statement to insert zeros of the proper format to expand a numeric field before SUM processing to prevent arithmetic overflow. However, you will usually want to use the OUTREC control statement rather than the INREC control statement to expand the record because OUTREC processing takes place after records are sorted or merged. If you use the INREC control statement to reformat the input record, remember to use the post-INREC field positions when you specify the SORT, MERGE, SUM, OUTREC, and/or OUTFIL control statements. If the SEQNUM function is used in a SORT application to insert a sequence number field in the record, this field will reflect the order of the records prior to sorting. In a MERGE application, the field will reflect the order of the records as they were read from each input in the merge.

INREC Control Statement Format


The format of the INREC control statement is illustrated below:

INREC FIELDS=(...) Figure 18. INREC Control Statement Format

FIELDS Parameter (Required)


The FIELDS parameter specifies the data fields to be included in the application. See OUTREC Control Statement on page 2.97 for a complete description of the FIELDS parameter.

2.38

SyncSort for z/OS 1.2 Programmers Guide

INREC
Sample INREC Control Statement
INREC FIELDS=(1:1,20,21:40,15,ZD,PD,29:60,5) Figure 19. Sample INREC Control Statement This INREC control statement specifies three data fields from an 80-byte record: The first field begins in byte 1 of the input record and is 20 bytes long. The second field begins in byte 40 of the input record and is a 15-byte ZD field. The data format is to be converted to PD. Since the input field contains 15 decimal digits, the converted PD output field created by SyncSort will be 8 bytes long. The third field begins in byte 60 of the input record and is 5 bytes long.

These three fields have been positioned to begin in bytes 1, 21, and 29, as indicated by their column prefixes. The reformatted input record is now just 33 bytes long. For comprehensive examples that illustrate the INREC control statement see Chapter 3.How to Use SyncSorts Data Utility Features.

Chapter 2. SyncSort Control Statements

2.39

JOIN JOIN Control Statement


The JOIN control statement specifies the disposition of paired and unpaired records in a join. When you do not provide a JOIN control statement in an application that has JOINKEYS control statements, SyncSort produces an output from the join operation that includes all paired records (an inner join). All unpaired records from both SORTJNF1 and SORTJNF2 are discarded. By providing a JOIN control statement, you can specify that unpaired records are to be included in the join output (an outer join). Parameters of the JOIN statement provide options as to which of the unpaired records are to be retained for output. See the descriptions of the JOINKEYS and REFORMAT control statements for additional information.

JOIN Control Statement Format


The format of the JOIN control statement is illustrated below: JOIN UNPAIRED [,F1] [,F2] [,ONLY] Figure 20. JOIN Control Statement Format

Retaining Unpaired Records


When joining files, a record from one file may or may not have a match in the other file. A match occurs when the contents of the join keys in the record from the first file equal the contents of the join keys in the record from the second file. By specifying the JOIN statement you can discard unpaired records from one or both files, or retain unpaired records from both files. To retain unpaired records from SORTJNF1 (a left outer join) in addition to all joined records, specify: JOIN UNPAIRED,F1

To retain unpaired records from SORTJNF2 (a right outer join) in addition to all joined records, specify: JOIN UNPAIRED,F2

2.40

SyncSort for z/OS 1.2 Programmers Guide

JOIN
To retain unpaired records from both SORTJNF1 and SORTJNF2 (a full outer join) in addition to all joined records, specify either: JOIN UNPAIRED,F1,F2

or simply: JOIN UNPAIRED

Discarding Paired Records


You have the option of discarding the paired records from a join and keeping only the unpaired ones. To do this, specify: JOIN UNPAIRED,ONLY

If you want to keep only the unpaired records from one SORTJNF1 or SORTJNF2, add either the F1 or the F2 parameter. Note: See the description of the REFORMAT statement for a discussion on what will appear in the record created by join processing when source fields from either SORTJNF1 or SORTJNF2 are not available due to a join unpaired operation. For more information, see Joining Records from Multiple Files on page 3.14.

Chapter 2. SyncSort Control Statements

2.41

JOINKEYS JOINKEYS Control Statement


Use the JOINKEYS statement to enable join feature processing and to identify the fields used to select records for join processing. The join feature joins records from two input files that are specified on the SORTJNF1 and SORTJNF2 DD statements. By default, when the JOINKEYS fields from m records in SORTJNF1 match the JOINKEYS fields from n records in SORTJNF2, all combinations of the records are joined using the REFORMAT statement, producing m*n records as input to subsequent SyncSort processing. (This is called an inner join.) See the discussion of the REFORMAT control statement for a description of how a record is constructed from the two records that have been selected as a match. If the optional JOIN UNPAIRED statement is specified, the unmatched records from the SORTJNF1 and/or SORTJNF2 files will also be REFORMATted and included in the input to SyncSort without being joined. (Including the unmatched records from SORTJNF1 is called a left outer join, including the unmatched records from SORTJNF2 is called a right outer join, and including all unmatched records is called a full outer join.) Optionally, only these unmatched records will become input to SyncSort. See the descriptions of the JOIN and REFORMAT statements for further details on their specification. The input files do not need to be presorted or have the same record type. Two JOINKEYS control statements are required one for each of the two files used in the join. The JOINKEYS control statement cannot be used with TAPESORT, MAXSORT, PARASORT, PIPESORT, SKIPREC, checkpoint, and merge exits (except for E35), and the DB2 Query feature.

2.42

SyncSort for z/OS 1.2 Programmers Guide

JOINKEYS
JOINKEYS Control Statement Format
The format of the JOINKEYS control statement is illustrated below: F1 JOINKEYS FILE= ,FIELDS= ( p 1 ,l 1 ,o 1 [ ,p 2 ,l 2 ,o 2 ... ] ) F2 [,SORTED] ALL NONE ,INCLUDE ,AND, ,OMIT = ,&, (c 1 c 2 ... ) ,OR, ,|, F ,TYPE= V Figure 21. JOINKEYS Control Statement Format

FILE Parameter (Required)


The FILE parameter connects the JOINKEYS control statement with the input file to be read. The specification of F1 connects the JOINKEYS control statement with the SORTJNF1 DD statement. The specification of F2 connects the JOINKEYS control statement with the SORTJNF2 DD statement. The format of the FILE parameter is illustrated in the following figure. F1 FILE= F2 Figure 22. FILE Parameter Format

FIELDS Parameter (Required)


The FIELDS parameter is required. It describes the fields to be used to match records from the two files, SORTJNF1 and SORTJNF2. The number of JOINKEYS fields and their lengths and sorted order (A or D) must be the same for both files, although their starting positions need not be the same. These fields will be treated as binary format for purposes of comparison during the match processing.

Chapter 2. SyncSort Control Statements

2.43

JOINKEYS
The join files do not need to be presorted on the fields specified on the JOINKEYS statement. By default, SyncSort will sort the records to the proper sequence before performing the join operation. If one or both of the files are already in the JOINKEYS FIELDS sequence, the SORTED parameter (see below) of the JOINKEYS statement can be specified. Note that for proper sequencing the fields must have been collated using binary as the field format. If the SORTED parameter can be used, the performance of the application will be improved since the need for SyncSort to preorder the records prior to join processing will be removed. The maximum number of JOINKEYS fields is 64 and all JOINKEYS fields will be treated as binary, though bit fields are not permitted. Each JOINKEYS field may be anywhere within the record through column 32750, the maximum length of a field is 4080 bytes, and the sum of all fields on a JOINKEYS statement cannot exceed 4080 bytes. For variable-length records, any JOINKEYS fields that are completely or partially missing will be padded with binary zeros when performing the comparison. Each field specified in the FIELDS parameter is identified by a position (p), length (l), and order (o). p The position value indicates the first byte of the field relative to the beginning of the input record. The length value indicates the length of the control field. The order value indicates the collating sequence of the field: A=Ascending order D=Descending order

l o

SORTED Parameter (Optional)


By default, SyncSort will presume that the records in the file are not presequenced per the JOINKEYS FIELDS specified. If the records are already collated in the proper sequence (sorted as binary fields, with the first field being the major field and the subsequent fields being progressively less significant fields), the SORTED parameter can be specified to improve the application's performance. SyncSort will sequence check each input file according to its JOINKEYS fields. If the SORTED parameter of the JOINKEYS statement was specified to indicate that the file was presorted and the sequence check fails, SyncSort will issue a critical error message containing the file number. The record number within the file will also be in the error message text whenever the INCLUDE/OMIT parameter of the JOINKEYS statement was not specified.

2.44

SyncSort for z/OS 1.2 Programmers Guide

JOINKEYS
INCLUDE/OMIT Parameter (Optional)
Specify the INCLUDE or OMIT parameter to indicate which records are to be included or omitted from the SORTJNFn file specified on the JOINKEYS statement. The INCLUDE/ OMIT processing occurs prior to the JOINKEYS field matching process. The format for the INCLUDE/OMIT parameter is illustrated below:

ALL NONE INCLUDE ,AND, = ,&, OMIT (c 1 c 2 ... ) ,OR, ,|, Figure 23. INCLUDE/OMIT Parameter Format See INCLUDE/OMIT Control Statement on page 2.19 for the detailed format of a comparison. The FORMAT=f parameter, which is permitted for the INCLUDE/OMIT control statement, is not permitted for the INCLUDE/OMIT parameter. Field formats must be specified on a field-by-field basis.

TYPE Parameter (Optional)


The TYPE parameter can be used to indicate the record format. TYPE=F indicates fixedlength records; TYPE=V indicates variable-length records. TYPE should be provided if the input file being specified is VSAM. If TYPE is not provided, TYPE=F will be assumed if the SORTJNFn file is VSAM. Note: If the TYPE specification differs from the RECFM DCB parameter for the SORTJNFn DD statement, the latter takes precedence. For more information, see Joining Records from Multiple Files on page 3.14.

Chapter 2. SyncSort Control Statements

2.45

MERGE MERGE Control Statement


The MERGE control statement is required for every merge application. The MERGE control statement can also define a copy application.

Cultural Environment Support


Cultural environment support allows you to choose an alternative set of collating rules based on a specified national language. The alternative collating applies to SORT/MERGE and INCLUDE/OMIT processing. For additional detail, see LOCALE on page 5.19.

MERGE Control Statement Format


The format of the MERGE control statement is illustrated below:

FIELDS=(p ,l ,f ,o [,p ,l ,f ,o ]...) 1 1 1 1 2 2 2 2 MERGE FIELDS=(p 1 ,l 1 ,o 1 [,p 2 ,l 2 ,o 2 ]...),FORMAT=f FIELDS=COPY

0 s , CENTWIN= --- f
,SKIPREC=n

,CKPT ,CHKPT

,EQUALS ,NOEQUALS ------------------------------------

,FILES=n

,STOPAFT=n Figure 24. MERGE Control Statement Format

FIELDS Parameter (Required for a Merge)


The FIELDS parameter is required for a merge. It describes the control fields. List the control fields in order of greatest to least priority, with the primary control field listed first, followed by progressively less significant fields. You can specify up to 128 control fields; however, if fields require complex internal processing, the limit for a particular execution may be less than 128. Each field specified in the FIELDS parameter is identified by its position p, length l, format f and order o. p The position value indicates the first byte of the field relative to the beginning of the input record after INREC and/or E32 processing, if specified, have completed.

2.46

SyncSort for z/OS 1.2 Programmers Guide

MERGE
Binary control fields can begin on any bit of a byte. When a binary field does not begin on a byte boundary, you must specify the bit number (0-7). For example, a position value of 21.3 refers to the 4th bit of the 21st byte of the record. l The length value indicates the length of the control field. The length value must be an integer number of bytes, except for the length of a binary control field which can be specified in bits. For example, a length value of 0.5 refers to a binary control field 5 bits long. For signed fields, the length value must include the area occupied by the sign. f The format value indicates the data format. For a list of valid formats, refer to the Format Code Chart in the next section, Valid Formats for Merge Control Fields. If all the control fields have the same format, you can specify the format value once by using the FORMAT=f subparameter. If you specify both the individual f values and the FORMAT subparameter, the individual f values will be used for fields where they are specified. The order value indicates how the field is to be collated: A=Ascending order D=Descending order E=As modified by an E61 exit

Valid Formats for Merge Control Fields


The following table lists the valid formats for merge control fields.

Code

Data Format

Field Length (bytes) 1 to 4091

AC*

EBCDIC characters are translated to their ASCII equivalents before merging. Character. Records are merged according to an alternate sequence specified either in the ALTSEQ control statement or as an installation default. Leading separate sign. An ASCII + or - precedes numeric field. One digit per byte. Trailing separate sign. An ASCII + or - trails numeric field. One digit per byte. Table 9. (Page 1 of 3) Format Code Chart

AQ*

1 to 4091

ASL*

2 to 256

AST*

2 to 256

Chapter 2. SyncSort Control Statements

2.47

MERGE
Field Length (bytes) 1 bit to 4092** 1 to 4092** 1 to 256

Code

Data Format

BI CH CLO* OL*

Binary. Unsigned. Character. Unsigned. Leading overpunch sign. Hexadecimal F,C,E, or A in the first 4 bits of your field indicates a positive number. Hexadecimal D or B in the first 4 bits indicates a negative number. One digit per byte. CMP=CLC is forced. Floating sign format. An optional leading sign may be specified immediately to the left of the digits. If the sign is a -, the number is treated as negative. For other characters, the number is treated as positive. Characters to the left of the sign are ignored. Leading separate sign. An EBCDIC + or - precedes numeric field. One digit per byte. CMP=CLC is forced. Trailing separate sign. An EBCDIC + or - follows numeric field. One digit per byte. CMP=CLC is forced. Fixed point. Signed. (Equivalent to Signed Binary.) Floating point. Normalized. Signed. Packed decimal. Signed. Packed decimal. 2-8-byte packed decimal data with the first digit and trailing sign ignored. The remaining bytes are treated as packed decimal digits. Typically PD0 is used with century window processing and Y2P format; Y2P processes the year, while PD0 processes month and day. Binary. 2-digit, 1-byte binary year data treated as a 4-digit year by CENTWIN (century window) processing.

CSF FS

1 to 16

CSL* LS* CST* TS* FI FL PD PD0*

2 to 256

2 to 256

1 to 256 2 to 16 1 to 256 2-8

Y2B*

Y2C*

Character. 2-digit character year data treated as a 4-digit year by CEN- 2 TWIN (century window) processing. Processing is identical to Y2Z fields. Table 9. (Page 2 of 3) Format Code Chart

2.48

SyncSort for z/OS 1.2 Programmers Guide

MERGE
Field Length (bytes) 1

Code

Data Format

Y2D*

Packed decimal. 2-digit, 1-byte packed decimal year data treated as a 4digit year by CENTWIN (century window) processing. Packed decimal. 2-digit, 2-byte packed decimal year data. Of the four packed digits contained in the 2 bytes, the first digit and trailing sign are ignored; the two inner digits are treated as a 4-digit year by CENTWIN processing. Character or zoned decimal. 2-digit, 2-byte valid numeric data treated as a 4-digit year by CENTWIN (century window) processing, as for Y2C and Y2Z. However, certain data are not treated as year data. Data with binary zeros (X'00') or a blank (X'40') in the first byte will be collated before valid numeric year data for ascending order (after year data for descending order). Data with all binary ones (X'FF') in the first byte will be collated after valid numeric year data for ascending order (before year data for descending order). Zones are ignored, as for Y2C and Y2Z, except for data where the first byte begins with X'00', X'40' or X'FF'. Full-date, character, binary, or packed decimal formats. Full-date data formats can be used to merge a variety of date fields. They can process dates ending or starting with year digits (x...xyy or yyx...x). They can also process non-date data commonly used with dates. For details, see page 2.155.

Y2P*

Y2S*

Y2T* Y2U* Y2V* Y2W* Y2X* Y2Y* Y2Z*

2-6

Zoned decimal. 2-digit, 2-byte zoned decimal year data treated as a 4digit year by CENTWIN (century window) processing. The zones are ignored. Processing is identical to Y2C fields. Zoned decimal. Trailing overpunch in the first 4 bits of the rightmost byte gives the sign. Hexadecimal F,C,E, or A indicates a positive number. Hexadecimal D or B indicates a negative number. One digit per byte. CTO forces CMP=CLC.

ZD CTO* OT*

1 to 256

Notes: * Cannot be used with Tape Sort. ** 4084 for variable-length records. 2043 for variable-length records. Table 9. (Page 3 of 3) Format Code Chart

Chapter 2. SyncSort Control Statements

2.49

MERGE
For information on the year data formats (Y2B, Y2C, Y2D, Y2P, Y2S and Y2Z) plus the related data format PD0, see CENTWIN Parameter (Optional) on page 2.51 and Converting Year Data with Century Window Processing on INREC, OUTREC, or OUTFIL OUTREC on page 2.112. Also see Specifying Field-to-Field Standard Comparisons for Year Fields in the INCLUDE/OMIT Control Statement section of this chapter.

Rules for Specifying Merge Control Fields


For fixed-length records, the sum of the lengths of all control fields cannot exceed 32752 bytes. When EQUALS is in effect, the sum of their lengths cannot exceed 4088 bytes. For variable-length records, all control fields must be located within the first 32750 bytes and the sum of their lengths cannot exceed 4084 bytes. When EQUALS is in effect, all control fields must be located within the first 32746 bytes and the sum of their lengths cannot exceed 4080 bytes. Control fields can be in contiguous or non-contiguous locations in the record. Remember that for variable-length records, the first 4 bytes are reserved for the Record Descriptor Word, so the first byte of the data portion of the record is byte 5. If the output file is a key-sequenced VSAM cluster, the VSAM key must be the first control field specified.

Comparing PD and ZD Control Fields


The CMP PARM determines how PD and ZD control fields will be compared. When CMP=CPD is in effect, the Compare Decimal (CP) instruction is used for the compare. ZD fields are packed and then compared. This method has performance advantages. However, invalid PD data may cause a system 0C7 abend and program termination. Moreover, the integrity of ZD fields is only guaranteed when they contain valid ZD data. The CMP=CPD method cannot be used for control fields that exceed 16 bytes, for variable-length merges when an even value (0, 2, 4, or 6) is specified for the VLTEST PARM, or for a Tape Sort. When CMP=CLC is in effect, no data validation is performed and the integrity of the output is maintained, even if the sign for a PD or ZD field is invalid. This method is always used if any control field exceeds 16 bytes, for variable-length merges when an even value is specified for the VLTEST PARM, and for a Tape Sort.

FIELDS=COPY (Required for a Copy)


Use FIELDS=COPY to copy one or more input files. (Multiple files can be copied if they are concatenated on the SORTIN DD specification.) Other control statements such as INCLUDE/OMIT, INREC, OUTREC, and OUTFIL may be specified in conjunction with a copy application, allowing you to edit and reformat the file(s) without any collation processing

2.50

SyncSort for z/OS 1.2 Programmers Guide

MERGE
The SUM control statement and an E32 exit cannot be specified with FIELDS=COPY. All Phase 3 exits can be used. The SORTIN DD statement defines the input to be copied. (SORTINnn DD statements are not processed when FIELDS=COPY is specified.)

CENTWIN Parameter (Optional)


The CENTWIN run-time or installation option acts on 2-digit year data. At run-time, CENTWIN can be specified as either a PARM option or a SORT/MERGE control statement parameter. CENTWIN generates a century window (for example, 1950 through 2049) that determines the century to which a 2-digit year belongs. CENTWIN ensures that year data spanning centuries will be sequenced correctly. Without CENTWIN processing, an ascending collation would sequence the year 01 before the year 98. With CENTWIN processing, the 01 field could be recognized as a twenty-first century date (2001) and would thus be sequenced after 98 (1998). For more information on specifying the CENTWIN option, see CENTWIN on page 5.7. CENTWIN processing only applies to data defined as year data formats (Y2B, Y2C, Y2D, Y2P, Y2S, and Y2Z) and the full-date formats (Y2T, Y2U, Y2V, Y2W, Y2X, and Y2Y). These data formats enable SyncSort to process 2-digit year fields as 4-digit years. A related data format, PD0, can be used to process the month and day portions of packed decimal date fields. To correctly specify date fields for CENTWIN MERGE processing, you should be familiar with the CENTWIN-related data formats. The following describes each of the year data formats and provides MERGE control statement examples: The Y2B Format This format is used to sequence 2-digit, 1-byte binary year data with CENTWIN processing. The binary values are converted to decimal, and the two low order digits are used as year data. Thus, while binary and decimal values range from 00 to 255, year values range from 00 to 99. The relationship between binary, decimal and year values is shown in the following table:

Binary Value X'00' to X'63' X'64' to X'C7' X'C8' to X'FF' Table 10.

Decimal Value 00 to 99 100 to 199 200 to 255

Year Value 00-99 00-99 00-55

Possible Values Representing Year Data with Y2B

Chapter 2. SyncSort Control Statements

2.51

MERGE
The Y2C and Y2Z Formats These formats represent 2-digit, 2-byte year data in either character (Y2C) or zoned decimal (Y2Z) format. Either Y2C and Y2Z formats can be used with data of the form X'xyxy' where y is a hexadecimal year digit 0-9 and x is hexadecimal 0 through F. Y2C and Y2Z ignore the x digits, leaving yy, the 2-digit unsigned year representation. Suppose you have a character or zoned decimal date field mmddyy that begins at byte 20. You can use either Y2C or Y2Z to process the yy field. As the following example indicates, you could specify three merge keys to correctly process this date:

MERGE FIELDS=(24,2,Y2C,A, 20,2,CH,A, 22,2,CH,A)

* Collates yy field as 4-digit year * Collates mm field * Collates dd field

The yy field (24,2) will be processed according to the century window setting. For example, if CENTWIN=1945, the field yy=45 will be sequenced as if it were 1945, and yy=44 would be sequenced as if it were 2044. Thus, for an ascending sequence, 44 would follow 45. The Y2D Format This format is used to sequence 2-digit, 1-byte packed decimal year data with CENTWIN processing. Use Y2D to extract the year data yy from packed decimal date fields. For example, consider a 3-byte packed decimal data field defined as X'yyddds' This field has the year yy in the first byte and the day ddd in bytes 2 and 3. The packed decimal sign s would be in the last digit (half byte) of the third byte. To merge this date field, which begins at byte 20, with 4-digit year processing, use the following MERGE control statement:

MERGE FIELDS=(20,1,Y2D,A, 21,2,PD,A) The Y2P Format

* Collates 2-digit year as 4-digit year * Collates ddds as 3 digits (ddd)

This format is used to sequence 2-digit, 2-byte packed decimal year data with CENTWIN processing. Use Y2P to extract the year data yy from packed decimal date fields spanning 2 bytes. For example, a packed decimal date of the form yymmdd would be stored as 4 bytes: yymmdd = X'0yymmddC'

2.52

SyncSort for z/OS 1.2 Programmers Guide

MERGE
where the trailing C (sometimes F) is a positive sign and the leading 0 pads the field on the left to make an even number of digits. Notice that the components of the date span bytes: 0y ym md dC Y2P handles this condition by ignoring the first and last half bytes of the 2-byte field specification. Thus, Y2P processes 0yym as yy, ignoring the leading digit (0) and the trailing digit m that is part of the month. The following example uses Y2P to collate the year portion of the date field, which begins at byte 20:

MERGE FIELDS=(20,2,Y2P,A) * Collates yy field as 4-digit year The field specification 20,2,Y2P treats X'0yym' as X'yy', and CENTWIN processing merges yy as a 4-digit year yyyy. The PD0 format, described below, can assist Y2P by processing month and day data that overlap year data in the original field. The Y2S Format This format is used to sequence 2-digit, 2-byte character or zoned decimal data. The Y2S format is identical to Y2C and Y2Z for valid numeric data, but Y2S treats data that begin with X'00', X'40' or X'FF' as non-year data. Thus, the Y2S format can distinguish records that have non-year data in the first byte of the year field, allowing such records to be collated differently from other records. Y2S treats non-year data as follows: Data with binary zeros (X'00') or a blank (X'40') in the first byte will not have century window processing applied to it. Instead, such data will be collated in sequence, before valid numeric year data for ascending order or after the year data for descending order. Data with all binary ones (X'FF') in the first byte will also not have century window processing applied to it. Instead, such data will be collated after valid year numeric data for ascending order or before the year data for descending order.

Zones are ignored, as for Y2C and Y2Z, except for data where the first byte begins with X'00', X'40' or X'FF'. As an example, suppose you want to preserve the input order of header and trailer records at the start or end of the file, and your header/trailer records are identified by binary zeros (X'00'), a blank (X'40') or binary ones (X'FF') in the first byte of the date field. The Y2S for-

Chapter 2. SyncSort Control Statements

2.53

MERGE
mat allows CENTWIN to identify the header/trailer records and treat them differently from other records. The PD0 Format This format is used to sequence 2-8 byte packed decimal data. PD0 ignores the first digit and trailing sign during processing. PD0 is normally used in conjunction with the Y2P data format. The Y2P format is used to process the 2-digit year portion of a packed decimal date field, while the PD0 format is used to process the month and day portion of the field. Although PD0 is typically used with Y2P, CENTWIN processing is not applied to PD0. Consider the packed decimal date field used in the Y2P example above: yymmdd = X'0yymmddC' where the trailing C (sometimes F) is a positive sign and the leading 0 pads the field on the left to make an even number of digits. Notice that the components of the date span bytes: 0y ym md dC The date can be processed as follows: Y2P processes the year component X'0yym' as X'yy'. PD0 processes the month and day components X'ymmddC' as X'mmdd'.

The following MERGE control statement can be used to collate the entire date with CENTWIN processing:

MERGE FIELDS=(20,2,Y2P,A, * Treats X'0yym' as X'yy'; collates yy as yyyy 21,3,PD0,A) * Treats X'ymmddC' as X'mmdd'

Full-Date Formats Full-date formats can be used to merge various date fields, processing dates ending or starting with year digits. They also process non-date data that are used with dates. For a full description of full-date formats, see the following section.

Using Full-Date Formats with CENTWIN


SyncSorts full-date data formats enable you to merge a variety of date fields. The full-date formats are Y2T, Y2U, Y2V, Y2W, Y2X, and Y2Y. These date formats can process dates ending or starting with year digits:

2.54

SyncSort for z/OS 1.2 Programmers Guide

MERGE
x...xyy (for example: qyy, mmyy, dddyy, or mmddyy) yyx...x (for example: yyq, yymm, yyddd, or yymmdd)

The full-date formats also process non-date data commonly used with the dates. SyncSort interprets two-digit years (yy) according to the century window specified by the CENTWIN option. CENTWIN processing does not apply to non-date data. In most cases, for CH, ZD, and PD date fields the full-date data formats are easier to use than the 2-digit date formats. The 2-digit formats can be more difficult because you must divide the date into its components. This requires care, particularly for PD dates, where date components (q, dd, mm, or yy) may span bytes or occupy only part of a byte. The fulldate formats, on the other hand, process such dates automatically. The table below describes the full-date formats. For date forms not in the table, use the 2digit year formats or the non-year formats. Note the following symbols used in the table: y x s 0 year digit (0-9) non-year digit (0-9) sign (hexadecimal A-F) unused digit

Chapter 2. SyncSort Control Statements

2.55

MERGE

Full-Date Format Y2T

Data Format CH, BI yyx

Date Form

Example Date Form yyq yymm yyddd yymmdd yyq yyddd yymm yymmdd qyy mmyy dddyy mmddyy qyy dddyy mmyy mmddyy

Length (bytes) 3 4 5 6 2 3 3 4 3 4 5 6 2 3 3 4

yyxx yyxxx yyxxxx Y2U PD yyx (X'yyxs') yyxxx (X'yyxxxs') Y2V PD yyxx (X'0yyxxs') yyxxxx (X'0yyxxxxs') Y2W CH, BI xyy xxyy xxxyy xxxxyy Y2X PD xyy (X'xyys') xxxyy (X'xxxyys') Y2Y PD xxyy (X'0xxyys') xxxxyy (X'0xxxxyys')

Table 11. Full-Date Formats

2.56

SyncSort for z/OS 1.2 Programmers Guide

MERGE
The table indicates the full-date formats that can be used with character (CH), binary (BI), or packed decimal (PD) data. Note the recognized non-date values: Character or binary (Y2T and Y2W full-date formats) C'0...0' (CH zeros) C'9...9' (CH nines) Z'0...0' (ZD zeros) Z'9...9' (ZD nines) X'00...00' (BI zeros) X'40...40' (blanks) X'FF...FF' (BI ones) Packed (Y2U, Y2V, Y2X, and Y2Y full-date formats) P'0...0' (PD zeros) P'9...9' (PD nines) The following two examples illustrate how you might use the Full-Date Formats table: Suppose you have a packed decimal (PD) date field of the form mmyy. To merge this field correctly, you would use the Y2Y 3-byte format from the table. Thus, if the field starts in position 30 and the records are in descending order, you would specify the following MERGE control statement: MERGE FIELDS=(30,3,Y2Y,D) Any PD fields of all PD zeros or all PD nines will be processed automatically as nondate data. Suppose you have a character (CH) date field of the form yymmdd. To merge this field correctly, you would use the Y2T 6-byte format from the table. Thus, if the field starts in byte 40 and the records are in ascending order, you would specify the following MERGE control statement: MERGE FIELDS=(40,6,Y2T,A) Any CH zeros, CH nines, BI zeros, blanks, and BI ones will be processed automatically as non-date data. Collating Sequence with Full-Date Formats For full-date formats, the yy component is always processed first (treated as primary key). This is so even when the yy is physically at the rightmost end of the field, as for Y2W, Y2X, and Y2Y. For example, a 6-byte Y2W field has the form xxxxyy. This is collated with the yy as the primary key and xxxx as the secondary key. Because SyncSort automatically collates the year character first, you dont have to deal with yy manually, for example by using PD0 and Y2D.

Chapter 2. SyncSort Control Statements

2.57

MERGE
It is important to understand that the xxxx component of a full-date format must be designed to collate as a unit. Suppose you have the 6-byte Y2T field yyxxxx. If you collate this field in ascending order, then yy collates first (the primary key) with xxxx collating second (secondary key). Consider two possibilities: If yyxxxx is actually yymmdd, you will be merging first by year, then month, then day. If yyxxxx is actually yyddmm, you will merging by year, then day, then month. In most cases, collating in this way would not be what you intended.

To correctly collate a date, the date components must be in an order suitable for collating. For example, mmddyy and yymmdd will collate correctly, but ddmmyy or yyddmm will not. For date forms that will not collate correctly, you must use one of the 2-digit year formats (Y2B, Y2C, Y2D, Y2P, Y2S, and Y2Z). The following table shows the order for ascending collation when using full-date formats with the CENTWIN option:

Full-Date Format Y2T Y2W

Date Format CH, BI

Ascending Sequence BI zeros Blanks CH/ZD zeros Lower century dates (e.g. 1980) Higher century dates (e.g. 2010) CH/ZD nines BI ones PD zeros Lower century dates (e.g. 1980) Higher century dates (e.g. 2010) PD nines

Y2U Y2V Y2X Y2Y

PD

Table 12. Ascending Sequences For descending sequence, the collation order is reversed. Other date formats (non-full-date), with the exception of Y2S, do not process non-date data; their sequence for ascending order begins with lower century dates and ends with higher century dates.

CKPT/CHKPT Parameter (Optional)


The CKPT/CHKPT parameter instructs SyncSort to take a checkpoint at every end-of-volume of a SORTOUT data set when OUTFIL is not used. Either spelling is accepted.

2.58

SyncSort for z/OS 1.2 Programmers Guide

MERGE
This parameter requires a SORTCKPT DD statement. It cannot be specified in conjunction with a user-issued STIMER macro or an incore sort. Checkpoints cannot be taken within a user exit routine. See Chapter 13.Performance Considerations for an explanation of the Checkpoint/Restart feature.

EQUALS/NOEQUALS Parameter (Optional)


The EQUALS parameter insures that equal-keyed records are merged in the order of their respective files. Equal-keyed records from the lowest numbered SORTINnn file are written before those from the second input file, etc. NOEQUALS, the default, specifies that equalkeyed records from different files be written in random order. The order of equal-keyed records within each input file is always preserved during a merge, whether or not the EQUALS parameter is specified. When the EQUALS parameter is used with the SUM control statement, the first of the equal-keyed records is retained with the sum; all other records are deleted after the specified field(s) have been summed. EQUALS/NOEQUALS can also be specified as a PARM option on the EXEC statement. If this option is specified both on the MERGE control statement and as a PARM option, the MERGE specification takes precedence.

FILES Parameter (Optional)


The FILES=n parameter specifies the number of input files that an E32 exit will supply to the merge. The n value can be any number up to 100. Specifying the FILES parameter both on the MERGE control statement and in the 24-bit parameter list will cause SyncSort to terminate with a critical error. The FILES parameter cannot be specified as a PARM on the EXEC statement or in a $ORTPARM data set.

SKIPREC Parameter (Optional)


The SKIPREC=n parameter instructs SyncSort to skip a decimal number of records before the input file is copied. The n records skipped are deleted from the input file before INCLUDE/OMIT processing, if specified, takes place. The SKIPREC parameter should only be specified for a MERGE FIELDS=COPY operation. SKIPREC will be ignored when doing a merge of SORTINnn data sets. If SKIPREC is specified as a PARM option as well as on the MERGE control statement, the PARM specification takes precedence.

Chapter 2. SyncSort Control Statements

2.59

MERGE
STOPAFT Parameter (Optional)
The STOPAFT=n parameter specifies the number of records to be copied. These will be the first n records after INCLUDE/OMIT and SKIPREC processing, if specified, have completed. The STOPAFT parameter should only be specified for a MERGE FIELDS=COPY operation. STOPAFT will be ignored when doing a merge of multiple SORTINnn data sets. If STOPAFT is specified as a PARM option as well as on the MERGE control statement, the PARM specification takes precedence.

Sample MERGE Control Statements


MERGE FIELDS=(1,5,CH,A,10,2,PD,D,30,4,BI,A) Figure 25. Sample MERGE Control Statement This sample MERGE control statement specifies three merge control fields: The first, or primary, control field begins in byte 1, is 5 bytes long, is in character format and is to be merged in ascending order. The second control field begins in byte 10, is 2 bytes long, is in packed decimal format and is to be merged in descending order. The third control field begins in the third bit of byte 30, is 4 bytes long, is in binary format and is to be merged in ascending order.

MERGE FIELDS=COPY,STOPAFT=200 Figure 26. Sample MERGE Control Statement This MERGE statement specifies a copy operation. Only the first 200 records will be copied.

2.60

SyncSort for z/OS 1.2 Programmers Guide

MODS MODS Control Statement


The MODS control statement specifies a user exit routine and is required with an exit. Refer to Chapter 7.The Coding and Use of Exit Programs for a detailed explanation of how to specify exit programs.

MODS Control Statement Format


The format of the MODS control statement is illustrated below.

MODS exit-name1=(parameters1),...,exit-name16=(parameters16) where parameters = ,N ,S ,C ,E ,X ,T

r,b [,d]

Insert a positional comma if the d value is omitted but the link-editing code is supplied. Figure 27. MODS Control Statement Format If an application has more than one exit, specify the exit-name parameter for each exit. Up to 16 exits can be specified. Use commas to separate multiple exit-name parameters.

Exit-Name Parameter (Required)


The exit-name parameter identifies the exit and provides additional information. Replace 'exit-name' with an E followed by the appropriate exit number. The 16 valid exit-names are listed below.

Chapter 2. SyncSort Control Statements

2.61

MODS

Sort Phase 1 E11 E14 E15 E16 E17 E18 Exit E21 E25 E27

Sort Phase 2

Sort or Merge Phase 3

Copy

E15

Name

E61 Table 13.

E31 E32 (merge only) E35 E37 E38 E39 E61 Phases and Permissible Exits

E31 E35 E37 E38 E39

The exit-name parameter also provides the following information about the exit. r The r value specifies the name of the user exit routine. Any valid name is acceptable. If the exit routine resides in a library, specify the member name or alias name for the r value. For an exit coded in REXX, r represents the REXX exec name. The b value specifies the exact or estimated decimal number of bytes the exit routine requires in main storage. This number should include any additional main storage required by the exit (e.g., buffers, GETMAINs, etc.). Specify an estimate (without an E before the value) if the exact number is not known. This number should only include storage requirements below the 16-megabyte line. REXX exits have some additional storage requirements. REXX system modules and control blocks need 26K, and each EXEC that is called will require 12K of storage. In addition to any variables that the EXEC uses, all special SyncSort variables will require storage (including space for a record). d The d value identifies the DD statement name that specifies the library in which the exit routine resides. The JCL must include a DD statement specifying each library in which an exit routine resides. If the exit routine is to be placed in the input job stream, specify SYSIN for the d value. (If more than one

2.62

SyncSort for z/OS 1.2 Programmers Guide

MODS
exit routine is included in SYSIN, the exit routines must be specified in ascending numerical order by exit name.) For a Disk Sort, MAXSORT, or PARASORT, an exit routine that is a load module residing in a library identified in a LINKLIB, STEPLIB or JOBLIB DD statement does not require a d value specification or a DD statement defining a module library in the JCL. If the d value is omitted, insert a positional comma to indicate the missing value. For a Tape Sort, it is necessary to specify the LINKLIB, STEPLIB or JOBLIB DD statement and to include a DD statement defining the library. The exit-name parameter also specifies link-editing codes: N, S, C, E, X, or T. If the linkediting code is omitted, the installation setting determines whether or not the exit will be link-edited. The delivered default is T; however, it may have been reset to N at installation. Ideally, exit routines should be designed so that they do not require link-editing each time they are used. Link-editing consumes system resources and increases sort/merge execution time. When a link-editing code is specified, the name E10 is reserved and no Phase 1 exit or E61 exit can use this name as a CSECT or ENTRY name. Similarly, the names E20 and E30 are reserved and cannot be used by Phase 2 or Phase 3 exits. N The N value specifies that link-editing is not required. Link-editing has already taken place and SyncSort can directly invoke the routine. The S value specifies that link-editing is required. This value can only be used for E11, E21 and E31 exits. The S value also indicates that the exit routine can be link-edited separately from other exit routines specified for the same phase. The C value identifies a COBOL exit routine. COBOL exits must be link-edited before execution time. Only COBOL E15 and E35 exits can be specified, and COBOL exits cannot be specified for a Tape Sort. The E value identifies a C exit routine. C exits must be link-edited before execution time. Only C E15 and/or E35 exits can be specified, and C exits cannot be specified for a tape sort. The X value identifies a REXX exit routine. Only REXX E15 and E35 exits can be specified, and REXX exits cannot be specified for a Tape Sort. The T value specifies that SyncSort will dynamically link-edit the exit routine along with other routines specified for the same sort/merge phase.

Chapter 2. SyncSort Control Statements

2.63

MODS
Sample MODS Control Statement
MODS E15=(ADDREC1,600,MODLIB,N),E25=(ALTREC,500,SYSIN), E35=(ADDREC2,600,MODLIB,C) Figure 28. Sample MODS Control Statement This sample MODS control statement specifies the following information: An E15 exit is the first exit routine. ADDREC1 is the member name of the routine, which requires 600 bytes in main storage and resides in a library referenced by the DD statement named MODLIB. The routine does not require link-editing. An E25 exit is the second exit routine. ALTREC is the member name of the routine which requires 500 bytes in main storage. The exit is included in the SYSIN input stream. Because N is not specified, this routine will be link-edited. An E35 exit is the third exit routine. ADDREC2 is the member name of the routine, which requires 600 bytes in main storage and resides in a library referenced by the DD statement named MODLIB. This routine is a COBOL exit which has been link-edited before execution time.

Examples of JCL-initiated applications with exit routines are illustrated in Chapter 4.JCL and Sample JCL/Control Statement Streams.

2.64

SyncSort for z/OS 1.2 Programmers Guide

OMIT OMIT Control Statement


See INCLUDE/OMIT Control Statement on page 2.19 for an explanation of the OMIT control statement.

Chapter 2. SyncSort Control Statements

2.65

OUTFIL OUTFIL Control Statement


The OUTFIL control statement describes the output file(s). It is required to accomplish these three tasks: Create multiple output files. The OUTFIL parameters associated with this task are CONVERT, ENDREC, FILES, FNAMES, FTOV, INCLUDE/OMIT, NULLOFL, OUTREC, REPEAT, SAMPLE, SAVE, SPLIT, SPLITBY, STARTREC, VLFILL, and VLTRIM. Use the SortWriter facility. The OUTFIL parameters associated with this task are HEADER1, HEADER2, LINES, NODETAIL, REMOVECC, SECTIONS, TRAILER1, and TRAILER2. Reformat records after E35 processing. The OUTFIL parameter associated with this task is OUTREC.

The OUTFIL control statement cannot be used with MAXSORT.

OUTFIL Control Statement Format


The format for the OUTFIL control statement is illustrated below.

2.66

SyncSort for z/OS 1.2 Programmers Guide

OUTFIL

OUTFIL FILES = fileid ( fileid [ ,fileid ]... ) 1 2 ddname ,FNAMES = ( ddname 1 [ ,ddname 2 ]... ) ALL NONE ,INCLUDE ,AND, ,OMIT = ,&, (c 1 c 2 ... ) ,OR, ,|, [,REPEAT=n] [,STARTREC=n] [,ENDREC=n] n ,SAMPLE= (n,m) [,SAVE] [,SPLIT] [,SPLITBY=n] [,OUTREC=(field1 [,field2]...)] [,CONVERT] [,FTOV] [,VLFILL=f] [,VLTRIM=b] [,HEADER1=(field1 [,field2]...)] [,HEADER2=(field1 [,field2]...)] [,TRAILER1=(field1 [,field2]...)] [,TRAILER2=(field1 [,field2]...)] [,SECTIONS=(field1 [,field2]...)] n ANSI ,LINES = (ANSI,n) [,NODETAIL] [,REMOVECC] RC0 ,NULLOFL = RC4 RC16

Figure 29. OUTFIL Control Statement Format

Chapter 2. SyncSort Control Statements

2.67

OUTFIL
The Multiple Output Capability
Use the OUTFIL control statement to create multiple files without making multiple passes through the input data. The output files can be treated the same or differently: The output files can contain the same or different records. The records in the output files can be identically or differently formatted. Whether the input files are fixed-length or variable-length, the output files may be either.

Note that all the output files will be sequenced in the same way, as specified on the SORT or MERGE control statement. If you need to sort the output files differently, you should use PipeSort, a Syncsort product that works with SyncSort for z/OS to reduce total elapsed time by generating multiple, differently sequenced output files from a single read of the input data.

The SortWriter Capability


The SortWriter capability of OUTFIL can produce completely formatted reports. The report writing features, which can be specified differently for each output file, can accomplish these tasks: Arrange the report into pages. Divide the report into sections. Format headers and trailers for sections, pages, and the complete report. Create multiple lines of output from each input record. Convert and edit numeric data. Provide TOTAL and SUBTOTAL capabilities for data fields in a specific part of a report. Provide MIN, MAX, AVERAGE, SUBMIN, SUBMAX, and SUBAVG capabilities for data fields in a specific part of a report. Provide COUNT and SUBCOUNT capabilities for records in a specific part of a report.

Once formatted, output files can be assigned to any tape, disk, or unit record device for subsequent printing.

2.68

SyncSort for z/OS 1.2 Programmers Guide

OUTFIL
FILES Parameter (Optional)
The FILES parameter connects the OUTFIL control statement with one or more output files. The files specified on this parameter, along with any specified on the FNAMES parameter, will constitute the ddnames to receive output for this OUTFIL specification. The format of the FILES parameter is illustrated in the following figure.

fileid FILES = (fileid 1 [,fileid 2 ] ...) where: OUT fileid = x xx Figure 30. FILES Parameter Format The fileid identifies the output file and connects the OUTFIL control statement with the corresponding SORTOUT, SORTOFx, or SORTOFxx DD statement. For example, FILES=OUT connects the OUTFIL control statement with the SORTOUT DD statement. Similarly, FILES=1 connects the OUTFIL control statement with the SORTOF1 DD statement, and FILES=01 connects the OUTFIL control statement with the SORTOF01 DD statement. The x can be any alphanumeric character or special character allowed by JCL DD statements. If multiple output files have identical specifications (that is, identical record selection, record reformatting, and report writing specifications), the FILES and/or FNAMES parameter can connect the OUTFIL control statement with more than one DD statement. For example, FILES=(OUT,02,03) connects the OUTFIL control statement with the SORTOUT, SORTOF02, and SORTOF03 DD statements. Such a set of output files is termed an OUTFIL group. If multiple output files have different specifications, then each file is specified on a separate OUTFIL control statement with one FILES and/or FNAMES parameter on each control statement. If a SORTOUT ddname is defined in the JCL and does not appear in any FILES or FNAMES specification, it will be written to without any OUTFIL processing. If an inline E35 exit has been specified, OUTFIL is ignored. If neither a FILES nor FNAMES parameter is specified on an OUTFIL control statement, the default ddname of SORTOUT will be used. If a 4-byte ddname prefix is in effect, the default SORTOUT ddname will be ppppOUT, where pppp is the prefix; adding FILES=xx would connect to the ppppOFxx DD statement.

Chapter 2. SyncSort Control Statements

2.69

OUTFIL
FNAMES Parameter (Optional)
The FNAMES parameter connects the OUTFIL control statement with one or more output files. The files specified on this parameter, along with any specified on the FILES parameter, will constitute the ddnames to receive output for this OUTFIL specification. The format of the FNAMES parameter is illustrated in the following figure.

ddname FNAMES= (ddname 1 [,ddname 2 ]...) Figure 31. FNAMES Parameter Format ddname is a 1 to 8-character ddname that corresponds to a DD statement provided in the JCL. If multiple output files have identical specifications (that is, identical record selection, record reformatting, and report writing specifications), the FNAMES and/or FILES parameter can connect the OUTFIL control statement with more than one DD statement. For example, FNAMES=(FILE1OUT,FILE2OUT,FILE3OUT) connects the OUTFIL control statement with the three listed DD statements. Such a set of output files is termed an OUTFIL group. If multiple output files have different specifications, then each file is specified on a separate OUTFIL control statement with one FNAMES and/or FILES parameter on each control statement. If a SORTOUT ddname is defined in the JCL and does not appear in any FILES or FNAMES specification, it will be written to without any OUTFIL processing. If an inline E35 exit has been specified, OUTFIL is ignored. If neither a FILES nor FNAMES parameter is specified on an OUTFIL control statement, the default ddname of SORTOUT will be used. If a 4-byte ddname prefix is in effect, the default SORTOUT ddname will be ppppOUT, where pppp is the prefix.

INCLUDE/OMIT Parameter (Optional)


Specify the INCLUDE or OMIT parameter to indicate which records are to be included in or omitted from each output file. These parameters let you create multiple output files which contain different records. The default is to include all sorted or merged records in the output file. The comparison determines which records are included or omitted. When no data records are to be included in the output file(s) (when running a test, for example), specify either INCLUDE=NONE or OMIT=ALL.

2.70

SyncSort for z/OS 1.2 Programmers Guide

OUTFIL
Note: The location within the data records of the fields specified in the INCLUDE/OMIT parameter will be based on the formatting of the record after processing by an E15/E32 exit, the INREC control statement, the OUTREC control statement, and an E35 exit, but before processing due to the OUTREC and/or report writing parameters of the OUTFIL control statement. The following four parameters (STARTREC, ENDREC, SAVE, and SPLIT) are related to the previous parameter (INCLUDE/OMIT) in that they specify records to be included for OUTFIL processing. However, these four options specify records in bulk rather than through a comparison condition.

REPEAT Parameter (Optional)


The REPEAT=n parameter enables each output record to be written multiple times. n specifies the number of times each OUTFIL output record is written. The minimum value for n is 2. REPEAT can be used with the OUTFIL OUTREC multi-line feature (designated by a / in the OUTREC specification). When this is done, each line will be written n times defined by the OUTREC specification. All occurrences of the first line will be written followed by all the occurrences of the second, and so on. The REPEAT parameter cannot be used with LINES, HEADER1, TRAILER1, HEADER2, TRAILER2, SECTIONS, and NODETAIL.

STARTREC Parameter (Optional)


Use the STARTREC=n parameter to specify the record number n of the first record to be processed by the OUTFIL specification in effect. All records prior to the specified record will be ignored for the OUTFIL group. The record number is determined by the sequence of records presented for OUTFIL processing. For more information, see SAMPLE Parameter (Optional) below.

ENDREC Parameter (Optional)


Use the ENDREC=n parameter to specify the record number n of the last record to be processed by the OUTFIL specification in effect. All records after the specified record will be ignored for the OUTFIL group. The record number is determined by the sequence of records presented for OUTFIL processing.

SAMPLE Parameter (Optional)


The SAMPLE=n and SAMPLE=(n,m) parameters allow the selection of a sample of records from an OUTFIL group. A specific interval and number of records in that interval can be specified. The sample process will take place within the range of records specified by

Chapter 2. SyncSort Control Statements

2.71

OUTFIL
STARTREC or ENDREC if they are specified. SAMPLE=n and SAMPLE=(n,m) are mutually exclusive. The sample consists of the first m records in every nth interval. n specifies the interval size. The minimum value for n is 2 (sample every other record). m specifies the number of records to be processed in each interval. The minimum value for m is 1 (process the first record in each interval). If m is not specified, 1 is used for m. If m is specified, it must be less than n.

SAVE Parameter (Optional)


Use SAVE to include records for OUTFIL processing that have not been included in any other OUTFIL group. If SAVE is specified on more than one OUTFIL group, then each of these OUTFIL groups get the records that were discarded from all other OUTFIL groups that do not have SAVE. The OUTFIL INCLUDE/OMIT parameter is mutually exclusive with the SAVE parameter. Only one of these parameters can be specified for an OUTFIL group. Note that if the SORTOUT data set has not been associated with any OUTFIL control statement but is present in the JCL, the SORTOUT data set will receive a copy of all records prior to OUTFIL processing. This does not affect the SAVE operation, since SAVE is only pertinent to other OUTFIL group specifications.

SPLIT Parameter (Optional)


The SPLIT parameter of the OUTFIL control statement causes output records to be distributed in rotation among files in an OUTFIL group. In the normal case, when the SPLIT parameter is not used, the output files in the group will contain the same records. SPLIT distributes the output records. The following OUTFIL control statement will distribute records among three output files:

OUTFIL FILES=(01,02,03),SPLIT Figure 32. Sample OUTFIL Control Statement with SPLIT For the above example, the first record will be written to the SORTOF01 data set; the second, to SORTOF02; the third, to SORTOF03. The fourth record will be written to SORTOF01 again, and so on in round-robin fashion. The OUTFIL control statement can contain an INCLUDE/OMIT and an OUTREC parameter, in which case the selected and reformatted subset of records will be distributed among the output files.

2.72

SyncSort for z/OS 1.2 Programmers Guide

OUTFIL
Note that the SPLIT parameter cannot be used with any report writing (SortWriter) functions. Specifically, report writing parameters (HEADERn, TRAILERn, SECTIONS, LINES, NODETAIL) cannot be specified on the OUTFIL control statement that defines the output group. SPLIT and SPLITBY=n are mutually exclusive. SPLITBY=1 is equivalent to SPLIT. SPLIT can be used with BatchPipes/MVS; that is, the output records can be distributed among BatchPipes/MVS data sets.

SPLITBY Parameter (Optional)


The SPLITBY=n parameter writes groups of records in rotation among multiple output data sets and distributes multiple records at a time among the OUTFIL data sets. n specifies the number of records to split by. The minimum value for n is 1. The SPLITBY parameter is similar to SPLIT, but SPLITBY can be used to rotate by a specified number of records rather than by one record, for example, records 1-10 to the first OUTFIL data set, records 11-20 to the second OUTFIL data set, and so on. For example, if SPLITBY=10 is specified for an OUTFIL group with three data sets: The first OUTFIL data set in the group receives records 1-10, 31-40, and so on. The second OUTFIL data set in the group receives records 11-20, 41-50, and so on. The third OUTFIL data set in the group receives records 21-30, 51-60, and so on.

SPLIT and SPLITBY=n are mutually exclusive. SPLITBY=1 is equivalent to SPLIT. Note that the SPLIT parameter cannot be used with any report writing (SortWriter) functions. Specifically, report writing parameters (HEADERn, TRAILERn, SECTIONS, LINES, NODETAIL) cannot be specified on the OUTFIL control statement that defines the output group.

OUTREC Parameter (Optional)


The OUTREC parameter indicates how the records are to be formatted in each output file. This parameter lets you create multiple output files which contain differently formatted records. When the records in all multiple output files are formatted and edited identically, it is more efficient to specify a single OUTREC control statement rather than several OUTREC parameters. The OUTREC parameter reformats the records that are to be included in the output file(s) after E35 processing, if specified. If no additional reformatting is required, omit this parameter.

Chapter 2. SyncSort Control Statements

2.73

OUTFIL
All references to field positions specified in the OUTREC parameter refer to the record after processing by an E15 exit, the INREC control statement, the OUTREC control statement, and an E35 exit but before insertion of ANSI control characters. The format of the OUTREC parameter is illustrated below.

OUTREC=(field1[,field2]...) Figure 33. OUTREC Parameter Format The format of the OUTFIL OUTREC parameter is generally identical to the format of the FIELDS parameter of the OUTREC control statement. (See the subsections dealing with the FIELDS parameter in OUTREC Control Statement on page 2.97.) Note, however, that FIELDS= is not used with OUTFIL OUTREC. In addition, OUTFIL OUTREC accepts the / subparameter and can be used with the VLFILL parameter. [n]/ The / subparameter indicates the end of a line and can be used to create multiple output lines from a single input record. Multiple slashes (coded //.../ or n/) can be used to specify leading, trailing, or embedded blank lines. At the beginning or end of the OUTREC parameter, n/ produces n blank lines. Embedded within the OUTREC parameter, n/ produces n-1 blank lines. The / subparameter is most useful for its ability to accommodate records whose lengths exceed the width of the physical page. For an example of the / subparameter, see Printing Input Records on Multiple Output Lines on page 3.37. The / subparameter may not be used when LINES=ANSI or LINES=(ANSI,n) has also been specified on the OUTFIL control statement.

The VLFILL Parameter (Optional)


The VLFILL parameter is used in conjunction with OUTREC or OUTREC CONVERT to specify a fill byte to be used for any missing p,l field bytes. The VLFILL parameter has two functions: It enables a variable-length OUTFIL OUTREC non-CONVERT application to continue processing when there is an input record with missing field bytes in a p,l field specification. It provides a means to override the default fill byte used in an OUTFIL OUTREC CONVERT application when there are missing bytes in a p,l field specification.

2.74

SyncSort for z/OS 1.2 Programmers Guide

OUTFIL
In the first instance, if VLFILL has not been specified the application will terminate with the critical error WER244A. In the second case, by default, spaces will be used for missing field bytes. f specifies a byte to be used for missing field bytes. f can be specified as either a character or hexadecimal value. Specify either C'x' where x is a single EBCDIC character or X'hh' where hh represents a hexadecimal digit pair (00-FF). Note: If VLFILL is specified, the OUTREC parameter must also be specified. VLFILL is ignored when the FTOV parameter is used.

CONVERT Parameter (Optional)


The CONVERT parameter is used in conjunction with the OUTREC parameter to convert variable-length records to fixed-length records. The records do not require an RDW and will be written to the output file(s) with a RECFM of F or FB. When using CONVERT, you no longer need to apply the rules for Specifying the FIELDS parameter for Variable-Length Records found in the description of the OUTREC control statement. You cannot specify the variable portion of the input records (position without length) when using CONVERT. All other p,l data fields that are not present will be filled with blanks by default. The OUTFIL VLFILL parameter can be used to specify a different fill byte for any missing fields (see above description). Notes: If CONVERT is specified, the OUTREC parameter must also be specified. CONVERT cannot be used with the FTOV parameter.

FTOV Parameter (Optional)


The FTOV parameter converts fixed-length input records to variable-length output records. FTOV can be used both with and without the OUTREC parameter. When FTOV is used with the OUTREC parameter, the variable-length record is created from the specified fields of the fixed-length record. When FTOV is not used with the OUTREC parameter, the variable-length record is created from the whole fixed-length record. Notes: FTOV cannot be used with CONVERT. If the input record is variable-length, FTOV, if specified, will be ignored. FTOV can be used with the VLTRIM parameter to delete pad bytes at the end of a record. For an example of an OUTFIL control statement that uses the FTOV parameter, see Figure 44 on page 2.96.

Chapter 2. SyncSort Control Statements

2.75

OUTFIL
VLTRIM Parameter (Optional)
The VLTRIM parameter defines a byte to be deleted from the end of a variable-length record. All prior occurrences of this byte will also be deleted until a byte that is not equal to the trim byte is found. The resulting records are decreased in record length. However, VLTRIM will not delete the first data byte, the ANSI carriage control character, or the Record Descriptor Word (RDW). The format of the VLTRIM parameter is illustrated below.

VLTRIM=b b specifies the byte to be deleted from the end of the record. b can be specified as either a character or hexadecimal value. Specify either C'x' where x is a single EBCDIC character or X'hh' where hh represents a hexadecimal digit pair (00-FF). Note: VLTRIM is ignored if used with fixed-length output records. For an example of an OUTFIL control statement that uses the VLTRIM parameter, see Figure 44 on page 2.96.

HEADER1/HEADER2 Parameters (Optional)


The SortWriter facility provides three types of headers: HEADER1, the report header HEADER2, the page header HEADER3, the section header.

HEADER1 and HEADER2 are parameters of the OUTFIL control statement. HEADER3 is a subparameter of OUTFILs SECTIONS parameter. Refer to SECTIONS Parameter (Optional) on page 2.89 for an explanation of how to specify HEADER3. The three types of headers function independently of each other. Each serves a different purpose. HEADER1 provides a header or a possible title page for the entire report. It appears only once at the beginning of the report on its own page. HEADER2 provides a page header or a running head for each page defined by the LINES parameter. It appears at the beginning or top of each page. HEADER3 provides a section header that appears at the beginning of each specified section and, optionally, at the top of each page (or directly below any HEADER2).

2.76

SyncSort for z/OS 1.2 Programmers Guide

OUTFIL
The chart below illustrates the format for HEADERs. The field entries represent the subparameters that can be specified for each HEADER entry.

HEADER1=(field1[,field2]...) HEADER2=(field1[,field2]...) HEADER3=(field1[,field2]...) Figure 34. HEADER Parameter Format The following HEADER Subparameters Format chart illustrates and defines the available subparameters. Each subparameter constitutes a separate field of the HEADER.

[n] X [n] 'literal string' [n] / p,l &DATE &DATE=(m 1 m 2 m 3 m 4 ) [ c: ] &DATENS=(xyz) &TIME &TIME=(hp) &TIMENS=(tt) &PAGE Figure 35. HEADER Subparameter Format c: Use the c: subparameter to define the column in which the specified field should begin. Used in conjunction with the X, 'literal string', and / subparameters, the n value defines the number (1-4095) of repetitions for each entry. Use the X subparameter to define the number of spaces. It must be coded to the immediate right of the n value, if specified. For more than 4095 spaces, two or more nX values should be specified. Use the 'literal string' subparameter to define a literal string. Specify the number of repetitions by coding n immediately before it. An apostrophe within a literal string must be specified as a double apostrophe; for example, C 'O"Leary'. Use the / subparameter to indicate the end of a line, force a carriage return, and separate text lines of a header. Multiple slashes (//.../ or n/) can be used to specify leading, trailing, or embedded blank lines. At the beginning or end of a header, n/

'literal string'

Chapter 2. SyncSort Control Statements

2.77

OUTFIL
produces n blank lines. Within a header, n/ produces n-1 blank lines. p,l Use the p and l subparameters to include a field (or fields) within a record in the header. For a HEADER1, the field(s) will be extracted from the first record in a file; for a HEADER2, the field(s) will be extracted from the first record on a page; for a HEADER3, the field(s) will be extracted from the first record in a section. p is the starting position of the field in the record; l is the length in bytes (1-255) of the field. Any number of fields can be specified. (Contiguous fields within a record can be specified with a single p,l entry, but their combined length cannot exceed 255 bytes.) The specified field(s) should be a character or alphanumeric string or a number in printable format, and the field(s) cannot be converted or edited. The &DATE subparameter specifies the current system date and requires 8 bytes to display mm/dd/yy. This form of the &DATE subparameter generates the current system date and controls the formatting of the date. You can specify the position of the year, month, and date, specify a separator character, and choose between 2-digit and 4-digit year representation. The positions m1 through m4 represent masks used to format the date. To specify the position of the month, day, and year, replace the m1, m2, and m3 positions, in any order, with M for the month (01-12), D for the day (01-31), and either Y or 4 for the year (where Y is a 2-digit year and 4 is a 4-digit year). Replace the m4 position with a separator character. For example, to print the date with the form yy-mm-dd, specify &DATE=(YMD-). For December 31, 1999, the date would appear as 99-12-31. A blank used as the separator character must be enclosed in apostrophes. An apostrophe used as the separator character must be specified as two apostrophes enclosed within apostrophes (''''). The field for this form of &DATE requires 8 bytes for a 2-digit year representation and 10 bytes for a 4-digit year. The M, D, and Y or 4 may only appear once in the mask. All four positions must be specified. &DATENS=(xyz) specifies that the current date is to appear in the report record in the form 'xyz', where x, y, and z indicate the order in which the month, day, and year are to appear and whether the year is to appear as two or four digits. For x, y, and z, use M to represent the month (01-12), D to represent the day (01-31), Y to represent the last two digits of the year (for example, 02), or 4 to

&DATE

&DATE=(m1m2m3m4)

2.78

SyncSort for z/OS 1.2 Programmers Guide

OUTFIL
represent the four digits of the year (for example, 2002). M, D, and Y or 4 can each be specified only once. For example, &DATENS=(DMY) would produce a date of the form 'ddmmyy' which on March 29, 2002, would appear as '290302'. &DATENS=(4MD) would produce a date of the form 'yyyymmdd' which on March 29, 2002, would appear as '20020329'. x, y, and z must be specified. &TIME The &TIME subparameter specifies the current time of day and requires 8 bytes to display hh:mm:ss, where hh is in 24-hour format. This form of the &TIME subparameter generates the current system time of day and controls the formatting of the time. You can print the time in 24-hour or 12-hour formats and specify the separator character between the hours, minutes, and seconds. The format for 24-hour time is hhpmmpss, where hh represents the hour (00-23), mm represents minutes (00-59), ss represents seconds (00-59), and p represents the separator character as specified by p in the &TIME=hp subparameter. The format for 12-hour time is hhpmmpss nn, where hh represents the hour (01-12), mm represents minutes (00-59), ss represents seconds (00-59), and p represents the separator character as specified by p in the &TIME=hp subparameter. The nn is am or pm as appropriate. To select 12-hour mode specify h as 12; to select 24-hour mode specify h as 24. The p specification represents the character to use as a separator. For example, to display the time in a 12-hour format with a period as a separator, specify &TIME=(12.). At 22:43:23 hours, the time would appear as 10.43.23 pm. A blank used as the separator character must be enclosed in apostrophes. An apostrophe used as the separator character must be specified as two apostrophes enclosed within apostrophes (''''). The field for this form of the &TIME subparameter requires 8 bytes for the 24-hour format and 11 bytes for the 12-hour format. &TIMENS=(tt) specifies that the current time is to appear in the report record in the form 'hhmmss' (24-hour time) or 'hhmmss xx' (12-hour time). If tt is 24, the time is to appear in the form 'hhmmss' (24hour time) where hh represents the hour (00-23), mm repre-

&TIME=(hp)

Chapter 2. SyncSort Control Statements

2.79

OUTFIL
sents the minutes (00-59), and ss represents the seconds (0059). For example, &TIMENS=(24) would produce a time of the form 'hhmmss' which at 08:25:13 pm would appear as '202513'. If tt is 12, the time is to appear in the form 'hhmmss xx' (12-hour time) where hh represents the hour (01-12), mm represents the minutes (00-59), ss represents the seconds (00-59), and xx is either 'am' or 'pm'. For a second example, &TIMENS=(12) would produce a time of the form 'hhmmss xx' which at 08:25:13 pm would appear as '082513 pm'. &PAGE The &PAGE subparameter sequentially numbers logical pages of the output report and requires 6 bytes. It produces a 6-digit sequential page number, right justified with leading zeros suppressed. &PAGE is ignored for HEADER1.

Rules for Specifying HEADER Subparameters


Observe the following guidelines when you specify HEADER subparameters: Separate subparameters with commas, except between c: and another subparameter. Commas are optional for the / subparameter. Enclose literals in single quotes. Specify blank fields of n bytes as nX. Headings specified with fewer blanks than the logical record length (LRECL) of the output record are automatically padded on the right with blanks. If a heading exceeds the logical record length (LRECL) of the output record, use the OUTREC control statement or the OUTREC parameter to expand the output record length so that it is at least as long as the longest header. For example, if the longest header is 115 characters and the output record length is 80 bytes, use the OUTREC control statement or the OUTREC parameter to insert a blank in position 115 of the output record. This will cause bytes 81 through 115 to be padded with blanks.

TRAILER Parameters (Optional)


The SortWriter facility provides three types of trailers: TRAILER1, the report trailer TRAILER2, the page trailer

2.80

SyncSort for z/OS 1.2 Programmers Guide

OUTFIL
TRAILER3, the section trailer.

TRAILER1 and TRAILER2 are parameters of the OUTFIL control statement; TRAILER3 is a subparameter of OUTFILs SECTIONS parameter. Refer to SECTIONS Parameter (Optional) on page 2.89 for an explanation of how to specify TRAILER3. The three types of trailers function independently of each other. Each serves a different purpose: TRAILER1 provides a trailer or a possible summary for the entire report. It appears only once at the end of the report on its own page. TRAILER2 provides a page trailer for each page defined by the LINES parameter. It appears at the end of each page. TRAILER3 provides a section trailer that appears at the end of each specified section and serves as a conclusion or summary for that section.

TRAILER1, TRAILER2, and TRAILER3 also provide TOTAL, SUBTOTAL, MIN, SUBMIN, MAX, SUBMAX, AVG, SUBAVG, COUNT, SUBCOUNT, COUNT15, and SUBCOUNT15 capabilities at report, page, and section levels. The chart below illustrates the format for TRAILERs. Its field entries represent the subparameters that can be specified for each TRAILER entry.

TRAILER1=(field1[,field2]...) TRAILER2=(field1[,field2]...) TRAILER3=(field1[,field2]...) Figure 36. TRAILER Parameter Format The following TRAILER Subparameters Format chart illustrates and defines the available subparameters. Each subparameter constitutes a separate field of the TRAILER.

Chapter 2. SyncSort Control Statements

2.81

OUTFIL

[n] X [n] 'literal string' [n] / p,l &DATE &DATE= ( m 1 m 2 m 3 m 4 ) &DATENS=(xyz) &TIME &TIME=(hp) &TIMENS=(tt) &PAGE TOTAL/TOT SUBTOTAL/SUB MIN ,Mm SUBMIN = (p,l,f ,EDIT=(...) [,SIGNS=(...)] [,LENGTH=(n)]) MAX ,M0 [c:] SUBMAX AVG SUBAVG COUNT ,Mm COUNT = ( ,EDIT=(...) [,SIGNS=(...)] [,LENGTH=(n)] ) ,M0 SUBCOUNT ,Mm SUBCOUNT = ( ,EDIT=(...) [,SIGNS=(...)] [LENGTH=(n)] ) ,M0 COUNT15 SUBCOUNT15 Figure 37. TRAILER Subparameters Format c: Use the c: subparameter to define the column in which the specified field should begin. Used in conjunction with the X, 'literal string', and / subparameters, the n value defines the number (1-4095) of repetitions for each entry. Use the X subparameter to define the number of spaces. It must be coded to the immediate right of the n value, if specified. For more than 4095 spaces, two or more nX values should be specified. Use the 'literal string' subparameter to define a literal string. Specify the number of repetitions by specifying n immediately

'literal string'

2.82

SyncSort for z/OS 1.2 Programmers Guide

OUTFIL
before it. An apostrophe within a literal string must be specified as a double apostrophe; for example, C 'O"Leary'. / Use the / subparameter to indicate the end of a line, force a carriage return, and separate text lines of a trailer. Multiple slashes (coded //.../ or n/) can be used to specify leading, trailing, or embedded blank lines. At the beginning or ending of a trailer, n/ produces n blank lines. Within a trailer, n/ produces n-1 blank lines. Use the p and l subparameters to include a field (or fields) within a record in the trailer. For a TRAILER1, the field(s) will be extracted from the last record in a file; for a TRAILER2, the field(s) will be extracted from the last record on a page; for a TRAILER3, the field(s) will be extracted from the last record in a section. p is the starting position of the field in the record; l is the length in bytes (1-255) of the field. Any number of fields can be specified. (Contiguous fields within a record may be specified with a single p,l entry, but their combined length may not exceed 255 bytes.) The specified field(s) should be a character or alphanumeric string, or a number in printable format, and the field cannot be converted or edited. If any variable-length record contains only a portion of the bytes in a specified field, those bytes will be included in the trailer and blanks will be substituted for the missing bytes. &DATE The &DATE subparameter specifies the current system date and requires 8 bytes to display mm/dd/yy. This form of the &DATE subparameter generates the current system date and controls the formatting of the date. You can specify the position of the year, month, and date, specify a separator character, and choose between 2-digit and 4-digit year representation. The positions m1 through m4 represent masks used to format the date. To specify the position of the month, day, and year, replace the m1, m2, and m3 positions, in any order, with M for the month (01-12), D for the day (01-31), and either Y or 4 for the year (where Y is a 2-digit year and 4 is a 4-digit year). Replace the m4 position with a separator character. For example, to print the date with the form yy-mm-dd, specify &DATE=(YMD-). For December 31, 1999, the date would appear as 99-12-31.

p,l

&DATE=(m1m2m3m4)

Chapter 2. SyncSort Control Statements

2.83

OUTFIL
The field for this form of &DATE requires 8 bytes for a 2-digit year representation and 10 bytes for a 4-digit year. The M, D, and Y or 4 may only appear once in the mask. All four positions must be specified. &DATENS=(xyz) specifies that the current date is to appear in the report record in the form 'xyz', where x, y, and z indicate the order in which the month, day, and year are to appear and whether the year is to appear as two or four digits. For x, y, and z, use M to represent the month (01-12), D to represent the day (01-31), Y to represent the last two digits of the year (for example, 02), or 4 to represent the four digits of the year (for example, 2002). M, D, and Y or 4 can each be specified only once. For example, &DATENS=(DMY) would produce a date of the form 'ddmmyy' which on March 29, 2002, would appear as '290302'. &DATENS=(4MD) would produce a date of the form 'yyyymmdd' which on March 29, 2002, would appear as '20020329'. x, y, and z must be specified. &TIME The &TIME subparameter specifies the current time of day and requires 8 bytes to display hh:mm:ss, where hh is in 24-hour format. This form of the &TIME subparameter generates the current time of day and controls the formatting of the time. You can print the time in 24-hour or 12-hour formats and specify the separator character between the hours, minutes, and seconds. The format for 24-hour time is hhpmmpss, where hh represents the hour (00-23), mm represents minutes (00-59), ss represents seconds (00-59), and p represents the separator character as specified by p in the &TIME=hp subparameter. The format for 12-hour time is hhpmmpss nn, where hh represents the hour (01-12), mm represents minutes (00-59), ss represents seconds (00-59), and p represents the separator character as specified by p in the &TIME=hp subparameter. The nn is am or pm as appropriate. To select 12-hour mode specify h as 12; to select 24-hour mode specify h as 24. The p specification represents the character to use as a separator. For example, to display the time in a 12-hour format with a period as a separator, specify &TIME=(12.). At 22:43:23 hours, the time would appear as 10.43.23 pm.

&TIME=(hp)

2.84

SyncSort for z/OS 1.2 Programmers Guide

OUTFIL
The field for this form of the &TIME subparameter requires 8 bytes for the 24-hour format and 11 bytes for the 12-hour format. &TIMENS=(tt) specifies that the current time is to appear in the report record in the form 'hhmmss' (24-hour time) or 'hhmmss xx' (12-hour time). If tt is 24, the time is to appear in the form 'hhmmss' (24hour time) where hh represents the hour (00-23), mm represents the minutes (00-59), and ss represents the seconds (0059). For example, &TIMENS=(24) would produce a time of the form 'hhmmss' which at 08:25:13 pm would appear as '202513'. If tt is 12, the time is to appear in the form 'hhmmss xx' (12-hour time) where hh represents the hour (01-12), mm represents the minutes (00-59), ss represents the seconds (00-59), and xx is either am or pm. For a second example, &TIMENS=(12) would produce a time of the form 'hhmmss xx' which at 08:25:13 pm would appear as '082513 pm'. &PAGE The &PAGE subparameter sequentially numbers logical pages of the output report and requires 6 bytes. It produces a 6-digit sequential page number, right justified with leading zeros suppressed. Use the TOTAL subparameter to specify that numeric data are to be accumulated and totaled at the end of a report, logical page, or section. After including the results in the appropriate trailer, the accumulator resets to zero. TOTALs appear in printable format. If a SyncSort editing mask is used for totaled data, the length of the output field is determined by the maximum permissible length of the data format, not by the specified length of the input field. This means that the default is to display 10 digits for BI and FI fields and 15 digits for PD, ZD, and CSF or FS fields. Internally, SyncSort maintains up to 15 digits for all data formats. Thus, if a BI or FI field total could exceed 10 digits, you should specify the LENGTH and/or EDIT subparameters to override the length of the output field. SUBTOTAL/SUB Use the SUBTOTAL subparameter to generate a running total of a field at the end of a report, logical page, or section. This subparameter functions like the TOTAL subparameter except the accumulator does not reset to zero. SUBTOTALs appear in

TOTAL/TOT

Chapter 2. SyncSort Control Statements

2.85

OUTFIL
printable format. If a SyncSort editing mask is used for subtotaled data, the length of the output field is determined by the maximum permissible length of the data format, not by the specified length of the input field. This means that the default is to display 10 digits for BI and FI fields and 15 digits for PD, ZD, and CSF or FS fields. Internally, SyncSort maintains up to 15 digits for all data formats. Thus, if a BI or FI field total could exceed 10 digits, you should specify the LENGTH and/or EDIT subparameters to override the length of the output field. MIN Use the MIN subparameter to obtain the minimum numeric value of an input field for all records within the report, logical page, or section. This value will be displayed in printable format. Use the SUBMIN subparameter to obtain the running minimum numeric value of an input field for all records within the report up to the point of the TRAILER. This value will be displayed in printable format. Use the MAX subparameter to obtain the maximum numeric value of an input field for all records within the report, logical page, or section. This value will be displayed in printable format. Use the SUBMAX subparameter to obtain the running maximum numeric value of an input field for all records within the report up to the point of the TRAILER. This value will be displayed in printable format. Use the AVG subparameter to obtain the average numeric value of an input field for all records within the report, logical page, or section. This value will be displayed in printable format. Use the SUBAVG subparameter to obtain the running average numeric value of an input field for all records within the report up to the point of the TRAILER. This value will be displayed in printable format. Use the p subparameter to indicate the position of the first byte of the numeric field. Use the l subparameter to indicate the length of the numeric field. Permissible lengths are 1-4 bytes for BI or FI, 1-8 bytes for PD, 1-15 bytes for ZD, and 1-16 for CSF or FS with a 15-digit

SUBMIN

MAX

SUBMAX

AVG

SUBAVG

2.86

SyncSort for z/OS 1.2 Programmers Guide

OUTFIL
limit. To determine the length of the output field, refer to How to Convert Numeric Data on page 2.110. For the (SUB)TOTAL and (SUB)AVG functions, fields are totaled internally as 8-byte PD fields. An overflow condition will occur if the positive or negative value of a totaled or subtotaled field exceeds the value that can be represented by such fields, and the execution will terminate with an error message. f Use the f subparameter to indicate the format of the numeric field. Replace f with BI, FI, PD, ZD, CSF, or FS. Use the Mm subparameter to indicate that one of the 27 SyncSort-supplied masks (M0-M26) should be used to format a field. Replace m with the mask number. The default is M0. For details, refer to The Mm Subparameter (Editing Masks) on page 2.121. Use the EDIT=(pattern) subparameter to indicate that a userprovided editing mask should be used to format a field. For details, see The EDIT Subparameter on page 2.119. Use the SIGNS subparameter to specify leading and/or trailing signs that will appear before or after the edited number. For details, refer to The SIGNS Subparameter on page 2.124. Use the LENGTH subparameter to alter the length of a field determined by the edit pattern and the internal field format. For details, refer to The LENGTH=n Subparameter on page 2.120. Use the COUNT subparameter to obtain a count of the number of records in either the entire report or a specific part of the report. In a TRAILER1, this field will contain a count of the total number of data records in the report. In a TRAILER2, it will contain a count of the number of data records on each page. In a TRAILER3, it will contain a count of the number of data records in each section. The count will be the number of data records before any multi-line OUTREC processing has been done. This number will be a right-justified 8-digit field with leading zeros suppressed. The maximum value is 99999999. This subparameter is identical to the COUNT subparameter except that a 15-digit count will be produced for the editing functions specified within the subparameters arguments. These arguments will determine the appearance of the field

Mm

EDIT=(pattern)

SIGNS=(...)

LENGTH=(n)

COUNT

COUNT=(...)

Chapter 2. SyncSort Control Statements

2.87

OUTFIL
within the trailer. For more information, see the following sections: COUNT15 The EDIT Subparameter on page 2.119 The Mm Subparameter (Editing Masks) on page 2.121 The LENGTH=n Subparameter on page 2.120 The SIGNS Subparameter on page 2.124.

This subparameter is identical to the COUNT subparameter except for the allowable size of the count number. For COUNT15 the number will be a right-justified 15-digit field with leading zeros suppressed. The maximum value is 999999999999999. Use the SUBCOUNT subparameter to obtain a running, or cumulative, count of the number of records throughout a report. In a TRAILER1, this field will contain a count of the total number of data records in the report. In a TRAILER2, it will contain a cumulative count of the number of data records on a page-bypage basis. In a TRAILER3, it will contain a cumulative count of the number of data records on a section-by-section basis. The count will be the number of data records before any multi-line OUTREC processing has been done. This number will be a right-justified, 8-digit field with leading zeros suppressed. The maximum value is 99999999. This subparameter is identical to the SUBCOUNT subparameter except that a 15-digit subcount will be produced for the editing functions specified within the subparameters arguments. These arguments will determine the appearance of the field within the trailer. For more information, see the following sections: The EDIT Subparameter on page 2.119 The Mm Subparameter (Editing Masks) on page 2.121 The LENGTH=n Subparameter on page 2.120 The SIGNS Subparameter on page 2.124.

SUBCOUNT

SUBCOUNT=(...)

SUBCOUNT15

This subparameter is identical to the SUBCOUNT subparameter except for the allowable size of the count number. For SUBCOUNT15 the number will be a right-justified 15-digit

2.88

SyncSort for z/OS 1.2 Programmers Guide

OUTFIL
field with leading zeros suppressed. The maximum value is 999999999999999.

Rules for Specifying TRAILER Subparameters


Observe the following guidelines when you specify TRAILER subparameters: Separate fields with commas, except for /, where commas are optional. Enclose literals in single quotes. Specify blank fields of n bytes as nX. If a SyncSort editing mask is used for totaled or subtotaled data (either by specification or by default), the length of the generated pattern will be determined by the maximum permissible length supported for that data format, regardless of the actual length of the field being totaled or subtotaled. Use the LENGTH subparameter to override the length of the pattern. Trailers specified with fewer blanks than the logical record length (LRECL) of the output record are automatically padded on the right with blanks. If a trailer exceeds the logical record length (LRECL) of the output record, use the OUTREC control statement or the OUTREC parameter to expand the output record length so that it is at least as long as the longest header. For example, if the longest trailer is 115 characters and the output record length is 80 bytes, use the OUTREC control statement or the OUTREC parameter to insert a blank in position 115 of the output record. This will cause bytes 81 through 115 to be padded with blanks.

SECTIONS Parameter (Optional)


The SECTIONS parameter allows the output report to be divided into sections. The format of the SECTIONS parameter is illustrated below.

SECTIONS=(field1[,field2]...) Each field is specified as follows: p,l [,subparameter1] [,subparameter2] ... Figure 38. SECTIONS Parameter Format The SECTIONS parameter identifies the control field(s) that determine or control section breaks. More than one control field can be specified to subdivide a report within sections. However, if more than one control field is specified, the specifications must be made in

Chapter 2. SyncSort Control Statements

2.89

OUTFIL
major to minor order. A major control field break causes all minor control fields to break at the same time. Each control field is identified by its position p and length l. p The position value indicates the first byte of the field relative to the beginning of the record after processing by an E15/E32 exit, the INREC control statement, the OUTREC control statement, and an E35 exit, if specified, but before processing by the OUTREC parameter and other report writing parameters of the OUTFIL control statement, if specified. The length value indicates the length of the field. The length must be an integer number of bytes and cannot exceed 256 bytes.

For each control field, one or more of the following subparameters may be specified: SKIP, HEADER3, or TRAILER3. The SECTIONS subparameters are described below.

P ,SKIP = nL [,TRAILER3=(...)] [,HEADER3=(...)] [,PAGEHEAD] Figure 39. Sections Subparameter SKIP The SKIP subparameter specifies the amount of spacing that should occur after a section is completed. This spacing will follow immediately after the last TRAILER3 for that section, if specified. SKIP=nL specifies that the next line of the report will appear after n number of blank lines, with n being between 0 and 255. SKIP=P specifies a page break following the completion of a section. The HEADER3 subparameter specifies a section header or title that will appear at the start of each new section. The HEADER3 format is identical to the format of the HEADER1/HEADER2 parameters. (See HEADER1/ HEADER2 Parameters for details.) The TRAILER3 subparameter specifies a section trailer that will appear at the end of each section. The TRAILER3 format is identical to the format of the TRAILER1/TRAILER2 parameters. (See TRAILER1/ TRAILER2 Parameters for details.) The PAGEHEAD subparameter may be specified in conjunction with the HEADER3 subparameter. The PAGEHEAD subparameter specifies that the HEADER3 appear at the top of each page following any HEADER2, as well as at the start of each new section. PAGEHEAD is ignored if no HEADER3 is specified.

HEADER3

TRAILER3

PAGEHEAD

2.90

SyncSort for z/OS 1.2 Programmers Guide

OUTFIL
A control field may be specified without any subparameters. This allows multiple noncontiguous control fields to be specified for each SECTIONS break field.

LINES Parameter (Optional)


Use the LINES parameter to define the logical pages constituting a report. The pages can be defined in three ways: Using the carriage control characters automatically supplied by SyncSort for z/OS Using ANSI control characters supplied by the user Using a combination of the above two methods.

Regardless of which method is selected, the number of lines defining a logical page must be equal to or greater than the total number of lines, including blank lines, required for all HEADER2, HEADER3, TRAILER2, and TRAILER3 entries plus at least one record. If multi-line OUTREC is used, all lines produced from each input record will be written to the same logical page. The format of the LINES parameter is illustrated below:

n LINES = ANSI (ANSI,n) Figure 40. LINES Parameter Format LINES=n If LINES=n is specified, paging is automatic and carriage control characters are added to the beginning of each record by SyncSort. Because SyncSort requires one byte for a control character, the LRECL specified in the SORTOUT, SORTOFx, or SORTOFxx DD statement must be one byte longer than the number of bytes specified for the output record length. Specify n as a value from 1 to 255. If report writing parameters are specified for the file(s) (e.g., HEADERs, TRAILERs, SECTIONS), the default is LINES=60. The LINES=n specification works in conjunction with any HEADERs and TRAILERs you have specified as follows: HEADER1, if specified, prints as a preface to the report. Its page is not numbered. An automatic page break occurs after HEADER1. Every nth line after the completion of HEADER1 will signal the start of a new page.

Chapter 2. SyncSort Control Statements

2.91

OUTFIL
A HEADER2 entry, if present, is the first line(s) on each page, followed by any HEADER3 entries that might be triggered either by control breaks or by PAGEHEAD specifications in the SECTIONS parameter. HEADER2 is part of the logical page. A HEADER3 entry, if present, is part of a section of the report. It prints as a header for the separate report sections. HEADER3s appear in major to minor order according to the order of their associated sections. If PAGEHEAD is specified, HEADER3 prints immediately below HEADER2, if specified, or at the top of the page if a HEADER2 is not specified. A HEADER3 will not print near the end of a page if there is not sufficient room on that page for at least one data record and a TRAILER2, if specified. A TRAILER3 entry, if present, is part of a section of the report. It prints as a conclusion or summary for the separate report sections. TRAILER3s will appear in major to minor order according to the order of their associated sections. A TRAILER2 entry, if present, will be the last line(s) on the logical page, preceded by any TRAILER3s triggered by coincidentally occurring control breaks. TRAILER2 is part of the logical page. TRAILER1 will be the last page of the entire report. Its page is not numbered.

Therefore, when LINES=n is specified, all HEADER2, HEADER3, TRAILER2, and TRAILER3 entries will be included as part of n (the total number of lines in a logical page) and will print as described above. LINES=ANSI If LINES=ANSI is specified, user-provided ANSI control characters define the logical pages. The first byte of each output record must contain an ANSI control character (inserted, for example, by an E35 program) which is valid for the specified output device type. For example, inserting a 0 in byte 1 of the output records produces double-spaced records. The ANSI control characters which can be used with the LINES=ANSI specification are summarized in the ANSI Control Character Chart below. If printed output is requested, the ANSI control characters do not print as part of the output record. If, however, the report is routed to a disk or tape device, the control characters are included in the output data. The LINES=ANSI specification works in conjunction with any HEADERs or TRAILERs you have specified. If you specify HEADER2, the ANSI specification affects this header as follows: After HEADER1 is output, the first logical page begins with the first line of HEADER2.

2.92

SyncSort for z/OS 1.2 Programmers Guide

OUTFIL
A logical page ends when data with a 1 in the first byte are encountered. The printing of a data record beginning with a 1 is delayed until after TRAILER2 and HEADER2, if specified, are output. When record printing resumes, this delayed record will be modified to have a control character +, which causes it to print over the last line of HEADER2 (or HEADER3, if HEADER3 appears at the top of the page). To prevent the data record from printing over a text line of a header, the header should end with at least one blank line, specified by a slash (/). To print HEADER2 at the top of a new physical page, the HEADER2's first line should begin with a 1. Because you are in complete control of the paging with LINES=ANSI, you can permit HEADER2 to appear between variable numbers of printed records.

LINES=(ANSI,n) If LINES=(ANSI,n) is specified, ANSI control characters govern vertical control, and the n specification provides additional automatic paging. Added flexibility is provided because the user can elect to double or triple space the output and still use automatic paging. When SyncSort encounters a data record with a 1 in the first byte, SyncSort begins a new logical page. If no data record begins with a 1 but the next data record would cause the number of lines on the page to exceed n, SyncSort treats the record as if it began with a 1 and begins a new page. Refer to the LINES=ANSI discussion for information on using a HEADER2 with ANSI control characters. Multiline OUTREC may not be used with LINES=ANSI or LINES=(ANSI,n).

Valid ANSI Control Characters


The following chart lists the ANSI control characters accepted by SyncSort.

Code blank 0 +

Interpretation Space one line before printing Space two lines before printing Space three lines before printing Suppress space before printing

Code 6 7 8 9

Interpretation Skip to channel 6 before printing Skip to channel 7 before printing Skip to channel 8 before printing Skip to channel 9 before printing

Table 14. (Page 1 of 2) ANSI Control Character Chart

Chapter 2. SyncSort Control Statements

2.93

OUTFIL
Code 1 2 3 4 5 Interpretation Skip to channel 1 before printing Skip to channel 2 before printing Skip to channel 3 before printing Skip to channel 4 before printing Skip to channel 5 before printing Code A B C V W Interpretation Skip to channel 10 before printing Skip to channel 11 before printing Skip to channel 12 before printing Select stacker 1 Select stacker 2

Table 14. (Page 2 of 2) ANSI Control Character Chart

NODETAIL Parameter (Optional)


The NODETAIL parameter instructs the SortWriter facility to generate an output report consisting only of header and trailer entries. Data records are not included in the output report when this parameter is specified. Thus, for example, it is possible to generate a report with section trailers containing totals and record counts without printing any data records.

REMOVECC Parameter (Optional)


The REMOVECC parameter generates reports that do not include ANSI carriage control characters that specify printer actions (for example, skipping a line or ejecting a page). The REMOVECC parameter omits the carriage control character from all of the report records. REMOVECC simplifies the removal of printer controls when output is to be displayed online or written to a list data set rather than a printout. When REMOVECC is used, the LRECL does not require an extra byte for the carriage control character, and the RECFM does not require the A (for ANSI); thus you would specify FB, not FBA.

NULLOFL Parameter (Optional)


RC0 NULLOFL= RC4 RC16

Figure 41. NULLOFL Parameter Format The NULLOFL parameter specifies the action to be taken when any non-SORTOUT OUTFIL data set contains no data records.

2.94

SyncSort for z/OS 1.2 Programmers Guide

OUTFIL
RC0 The delivered default instructs SyncSort to issue a return code of 0 if not overridden by a higher return code set for another reason. Instructs SyncSort to issue a WER461I warning message and continue processing. A return code of 4 will be issued if not overridden by a higher return code set for another reason.

RC4

RC16 Instructs SyncSort to issue a WER461A message and to terminate processing with a return code of 16.

Sample OUTFIL Control Statements


Example 1 The following example illustrates how to use the OUTFIL control statement to define multiple output files.

OUTFIL FILES=1,OUTREC=(10:1,20,40:45,5,50:60,8), INCLUDE=(21,2,CH,EQ,C'NY') OUTFIL FILES=2,OUTREC=(20:1,20,50:60,8), INCLUDE=(21,2,CH,EQ,C'MA') Figure 42. Sample OUTFIL Control Statement The two OUTFIL control statements illustrated above are required to create two different output files. The output records in the first file (SORTOF1) contain three fields from the input record. The first input record field begins in byte 1 and is 20 bytes long, the second input record field begins in byte 45 and is 5 bytes long, and the third input record field begins in byte 60 and is 8 bytes long. This file will include only those records with NY in bytes 21 and 22 of the input record. These three fields will begin in bytes 10, 40, and 50 of the output record. The output records in the second file (SORTOF2) contain two fields from the input record. The first input record field begins in byte 1 and is 20 bytes long, and the second input field begins in byte 60 and is 8 bytes long. This file will include only those records with MA in bytes 21 and 22 of the input record. These two fields will begin in bytes 20 and 50 of the output record.

Example 2

OUTFIL FILES=(01,02,03),OUTREC=(1:1,40,50:41,40) Figure 43. Sample OUTFIL Control Statement

Chapter 2. SyncSort Control Statements

2.95

OUTFIL
This OUTFIL control statement creates three identically formatted output files: SORTOF01, SORTOF02, and SORTOF03. These files may be written to the same output device or to three different output devices. The output records contain two input record fields. The first input record field begins in column 1. This field began in position 1 before OUTREC processing and is 40 bytes long. The second input record field begins in column 50. This field began in position 41 before OUTREC processing and is 40 bytes long. The two fields will begin in positions 1 and 50 after OUTREC has been processed.

Example 3 OUTFIL FTOV,VLTRIM=C'*',OUTREC=(1,7,9:8,8)

Figure 44. Sample OUTFIL Control Statement with FTOV and VLTRIM This OUTFIL control statement uses FTOV to convert fixed-length records to variablelength records and VLTRIM to remove the specified type of trailing bytes (in this case, asterisks). The control statement would produce the following output: Input Records RECORD1ABC***** RECORD2ABCDEF** RECORD3ABC****Z Output Records RECORD1 ABC RECORD2 ABCDEF RECORD3 ABC****Z Record Length (with 4-byte RDW) 15 18 20

Comprehensive examples illustrating the SortWriter facility and the multiple output capability of the OUTFIL control statement are provided in Chapter 3.How to Use SyncSorts Data Utility Features.

2.96

SyncSort for z/OS 1.2 Programmers Guide

OUTREC OUTREC Control Statement


The OUTREC control statement reformats the output records. Use the OUTREC control statement to accomplish the following tasks: Delete or repeat segments of the input records. Insert character strings between data fields. Insert binary zeros. Create a sequence number field. Convert numeric data to printable format or to another numeric data format. Perform arithmetic operations (multiplication, division, modulus, addition, subtraction) and minimum and maximum functions with numeric fields and constants. This horizontal arithmetic ability complements the vertical arithmetic already available with SUM and OUTFIL TOTAL, MIN, MAX, and AVG. Convert data to printable hexadecimal format. Translate the case of EBCDIC letters from uppercase to lowercase or lowercase to uppercase, or translate a field based on an ALTSEQ table in effect. Select, realign, and reorder data fields. Convert a variable-length record input file to a fixed-length record output file.

The OUTREC parameter of the OUTFIL control statement can also be used to accomplish any of the above tasks. The INREC control statement can also be used to accomplish any of the above tasks except for converting a variable-length record file to a fixed-length record file. Consider these guidelines when deciding whether to use the INREC control statement, the OUTREC control statement, or the OUTREC parameter of the OUTFIL control statement: Use the INREC control statement to delete irrelevant data fields, reformat numeric fields to a shorter length, or combine numeric fields with arithmetic operations and functions. Reducing the size of the input records before they are sorted or merged usually improves performance. Use either the OUTREC control statement or the OUTREC parameter of the OUTFIL control statement to expand the data record, create new numeric fields, realign data fields, convert and edit numeric data, and change from variable-length format to fixedlength format when you are creating one output file.

Chapter 2. SyncSort Control Statements

2.97

OUTREC
Use the OUTREC control statement when you are creating multiple output files with the same output record formatting. Use the OUTREC parameter of the OUTFIL control statement when you are creating multiple output files with different output record formatting. Use the OUTREC control statement if you need to convert a numeric field to printable format so it can be displayed in an OUTFIL header. Use the OUTREC parameter of the OUTFIL control statement when an E35 exit must process the records first. Use the OUTREC parameter of the OUTFIL control statement when you specify the TOTAL and/or SUBTOTAL subparameters of the TRAILER parameter so that the accumulator(s) can sum numeric fields before they have been converted to readable format and edited.

OUTREC Control Statement Format


The format for the OUTREC control statement is illustrated below.

OUTREC FIELDS = (field 1 [field 2 ( ] ...) [,CONVERT] ) Fields can be specified as follows: p,l [,subparameters] [n] X [n] X'hhhh...hh' [n] C'literal string' [n] Z [c:] 'date field' 'time field' SEQNUM,l,f ,START = 1 ,INCR = -- i

1 -- n

Figure 45. OUTREC Control Statement Format Note: The n/ entry and the VLFILL parameter cannot be used with the INREC or OUTREC control statement. They can only be used with the OUTREC parameter of the OUTFIL control statement. For a description of the n/ entry and the VLFILL parameter, see page 2.73. In the diagram above, there are two main types of fields: Data fields, represented by the p,l[,subparameters] Literal fields that are composed of the remaining field specifications in Figure 45.

2.98

SyncSort for z/OS 1.2 Programmers Guide

OUTREC
Data field specification is defined in the Data Field (p,l) Subparameters section below. For the specification of literal fields, see Specifying Literal Fields on page 2.115.

FIELDS Parameter (Required)


The FIELDS parameter specifies fields to be included in the output record. Fields can be data fields, spaces, hexadecimal digits, literal strings, binary zeros, current date and time literals, or sequence numbers. Each data field specified in the FIELDS parameter is identified by its position p and length l. c: The column value (optional) specifies the output column in which a field should begin. For INREC, the position value indicates the first byte of the field relative to the beginning of the input record after E15 processing, if specified, has completed. For OUTREC, the position value indicates the first byte of the field after both E15 and INREC processing, if specified, have completed. If the OUTREC parameter of the OUTFIL control statement is used, the position value refers to the record after E35 processing as well. The field must begin on a byte boundary. The length value indicates the length of the field. The length must be an integer number of bytes.

Specifying the FIELDS Parameter for Variable-Length Records


If you are not using the CONVERT option to convert variable-length records to fixed-length records, you must observe these rules when you specify the FIELDS parameter for variable-length records: Remember to specify 4 bytes for the Record Descriptor Word in the first output field. You can include the 4 bytes in the length value of the first field if the first field in the original data record is also the first field specified in the FIELDS parameter. To include any portion of the variable part of the input records, specify a position value without a length value as the last entry. The only subparameters you can specify after the position value are the HEX and TRAN conversion subparameters. (Refer to the FIELDS subparameters for an explanation of HEX and TRAN conversion.) If INREC or OUTREC processing changes the output record length, the contents of the Record Descriptor Word will be automatically revised by the sort.

Chapter 2. SyncSort Control Statements

2.99

OUTREC
Data Field (p,l) Subparameters
Use the FIELDS subparameters to accomplish these tasks: Specify the column in which a field should begin. Specify halfword, fullword, or doubleword alignment. Convert a numeric field to a printable format with editing capabilities. Convert numeric data to another numeric data format. Perform minimum and maximum functions and arithmetic operations (multiplication, division, modulus, addition, subtraction) with numeric fields and constants. Convert a field to its printable hexadecimal representation. Translate the case of EBCDIC letters from uppercase to lowercase or lowercase to uppercase, or translate a field based on an ALTSEQ table in effect.

The figure below illustrates how the FIELDS subparameters should be specified and describes their functions. For information on the EDIT, LENGTH, Mm, and SIGNS subparameters, see How to Convert Numeric Data on page 2.110.

f0 M0 expression , [,LENGTH=n] [ ,SIGNS= ( s 1 ,s 2 ,s 3 ,s 4 ) ] Mm EDIT=(pattern) a p,l , CHANGE=(........) [,NOMATCH=(....)] [c:] ,HEX LTOU p [,l] UTOL ,TRAN= ALTSEQ p,l,f (c) y 2f p,l,f y2f P

Figure 46. Fields Subparameters Format The following describes the c: subparameter:

2.100

SyncSort for z/OS 1.2 Programmers Guide

OUTREC
c: Use the c: subparameter to define the column in which the field should begin. SyncSort will add the appropriate number of blanks to achieve the proper alignment. This subparameter can be specified for all types of fields.

The term expression represents the following syntax:

p,l,f i +n -n [ ( ''expression 1 '' [,''operator'',''expression 2 '' ] ) ] Figure 47. Syntax for expression The following describes the elements of expression: p,l,fi This specifies the position, length, and format of an input field. (See the description of fi below for details.) This represents a positive numerical constant of up to 15 decimal digits. The + sign must be specified. This represents a negative numerical constant of up to 15 decimal digits. The - sign must be specified. An expression defines a numeric value. The simplest forms of an expression consist of a numeric data input field defined either by p,l,fi or a constant defined by +n or -n. Expressions can also be created by connecting these simple expressions with operators, as shown in the last line of the above syntax illustration. Parentheses may be used to change the default precedence order of the operators. Algebraic equations can thus be represented with an expression. A maximum value of 15 digits is permitted at all times in evaluating an expression. If this is exceeded, a critical error will be issued. Similarly, an attempted division by zero will also result in a critical error. The results of division will be rounded down to an integer. Once an expression has been defined, its value can either be converted to a numeric output data format or to a printable numeric format using editing masks. See How to Convert Numeric Data on page 2.110. The default is to use the M0 editing mask to create printable output. The number of digits in an expression is defined to be 15 (unless the expression is a simple p,l,fi field), so using the M0 default mask will create a 16-byte output field.

+n

-n

expression

Chapter 2. SyncSort Control Statements

2.101

OUTREC
The following are expressions: +10 10,2,Y2Z +10,ADD,10,2,Y2Z 1,4,ZD 10,2,PD +30 1,4,ZD,ADD,10,2,PD +30,MUL,(1,4,ZD,ADD,10,2,PD) +30,MUL,(1,4,ZD,ADD,10,2,PD),MIN,(5,5,ZD,DIV,+100) (+30,MUL,(1,4,ZD,ADD,10,2,PD)),MIN,(5,5,ZD,DIV,+100) operator Operations between two numeric fields or constants are performed with operators. There are two types of operators: function operators and arithmetic operators. The following are the function operators: MIN Generates the minimum arithmetic value of two specified fields. Generates the maximum arithmetic value of two specified fields.

MAX

The following are the arithmetic operators: MUL DIV MOD ADD SUB multiplication division modulus addition subtraction

The following rules of arithmetic precedence apply in computing an expression: Conditions within parentheses are evaluated first, from innermost to outermost parentheses. The arithmetic functions of minimum and maximum (MIN and MAX) are performed before the arithmetic operators (MUL, DIV, MOD, ADD, SUB). Within the arithmetic operators, multiplication (MUL), division (DIV), and modulus (MOD) are performed before addition (ADD) and subtraction (SUB). Operations within the same precedence level are performed from left to right.

2.102

SyncSort for z/OS 1.2 Programmers Guide

OUTREC
The result of the DIV operation is truncated (rounded down) to an integer. The MOD operation produces an integer remainder with the sign of the dividend. fi Use this parameter together with p,l to define the input format of a numeric field that is part or all of an expression. The expression will then be converted to either another numeric data format or to a printable format. In such cases, indicate the format of the data field that is to be converted by replacing fi with BI, FI, PD, ZD, CSF/FS, PD0, one of the SMF formats (DT1, DT2, DT3, TM1, TM2, TM3, and TM4), or one of the year data formats (Y2B, Y2C, Y2D, Y2P, Y2S, Y2Z, Y2T, Y2U, Y2V, Y2W, Y2X, Y2Y). Also use this parameter when a 2-digit packed decimal year value is to be expanded to a 4-digit packed decimal value. In such cases replace fi with Y2ID or Y2IP. The Y2ID and Y2IP formats cannot be used to form complex arithmetic expressions and do not allow the specification of mask (Mm), EDIT, SIGNS, or LENGTH. An l value indicating the length of the field must be specified in accordance with the following allowable values: for BI ... 1-4 inclusive for CSF or FS ... 1-16 inclusive (15 digit limit) for FI ... 1-4 inclusive for PD ... 1-8 inclusive for PD0 ... 2-8 inclusive for Y2B ... 1 for Y2C ... 2 for Y2D ... 1 for Y2ID ... 1 for Y2IP ... 2 for Y2P ... 2 for Y2S ... 2 for Y2Z ... 2 for ZD ... 1-15 inclusive for Y2T ... 3-6 inclusive for Y2U ... 2-3 inclusive for Y2V ... 3-4 inclusive for Y2W ... 3-6 inclusive for Y2X ... 2-3 inclusive for Y2Y ... 3-4 inclusive Field conversion of a single p,l,fi expression with a format of Y2B, Y2C, Y2D, Y2P, Y2S, Y2Z, Y2ID, or Y2IP does not default to the use of the M0 default output mask. The default will convert to a 4-digit 4-byte printable year. However, except for Y2S, Y2ID, and Y2IP,

Chapter 2. SyncSort Control Statements

2.103

OUTREC
these formats can be used to form expressions with operators. In this case, the default will use the M0 output mask with 15 decimal digits. The specification of an output numeric data format fo or mask Mm, EDIT, SIGNS, or LENGTH is permitted except when using Y2S, Y2ID, and Y2IP. Field conversion of a single p,l,fi expression with a format of Y2T, Y2U, Y2V, Y2W, Y2X, or Y2Y does not default to the M0 mask. These fields are converted to a printable year with the 2-digit year portion converted to a 4-digit value. The year portion of the date is converted to a 4-digit year using the century window defined by the CENTWIN parameter. The century window is not used for the special values, which are only expanded with characters of the proper format. The specification of an output numeric data format fo or mask Mm, EDIT, SIGNS, or LENGTH is not permitted. The following describes the other FIELDS subparameters: fo Use this subparameter to define the output numeric data format of an expression. When fo is specified, mask Mm, EDIT, and SIGNS cannot be specified. Indicate the desired format of the output field by replacing fo with BI, CSF/FS, FI, PD, or ZD. See How to Convert Numeric Data on page 2.110 for the default lengths of these fields. See The LENGTH=n Subparameter on page 2.120 for how this default may be changed. Use the Mm subparameter to indicate that one of the 27 SyncSortprovided editing masks, M0-M26, is to be used. Replace 'm' with the mask number. For details, see The Mm Subparameter (Editing Masks) on page 2.121. Use the EDIT subparameter to specify that a user-provided editing mask should be used to format the output fields. For details, see The EDIT Subparameter on page 2.119. Use the SIGNS subparameter to specify the signs that will appear before or after the edited number. For details, see The SIGNS Subparameter on page 2.124. Use the LENGTH subparameter to alter the length of the output field. This is normally determined by the number of numeric digits d and either the data format or the edit pattern and format of the edited field. For details, see The LENGTH=n Subparameter on page 2.120. Use this subparameter to tell SyncSort how the field should be aligned with respect to the start of the output record. Replace a

Mm

EDIT=(pattern)

SIGNS=(s1,s2,s3,s4)

LENGTH=n

2.104

SyncSort for z/OS 1.2 Programmers Guide

OUTREC
with H, F, or D to specify halfword (H), fullword (F), or doubleword (D) alignment. The alignment itself actually takes place after the column designation. It will automatically pad any provided field with the number of bytes of binary zeros required to achieve the specified alignment. This subparameter cannot be used in conjunction with data conversion. change-parm This variable represents the CHANGE subparameter. The CHANGE subparameter changes an input field to a replacement constant in the reformatted output record if the input field equals a search constant. For a complete description, see The CHANGE Subparameter on page 2.125. Use the HEX subparameter to convert a record field to its hexadecimal representation. Specify this subparameter immediately after the position p and the length l of the field to be converted. Specify p,l,HEX for both fixed-length records and the fixed-length portion of variable-length records. Specify p,HEX for the variable-length portion of variable-length records. Starting in position p of the input record, for a length of l, each byte will be converted to its hexadecimal representation. Note that in the reformatted record, the converted field will be twice the length of the original field. Use this subparameter to change the case of EBCDIC letters from lowercase to uppercase, uppercase to lowercase, or based on an alternate collating sequence (ALTSEQ) table in effect. Specify this subparameter immediately after the position p and the length l of the field to be converted. Specify p,l,TRAN for both fixed-length records and the fixed-length portion of variable-length records. Specify p,TRAN for the variable-length portion of variable-length records. Starting in position p of the input record, for a length of l, each byte will be converted as per specification. LTOU TRAN= UTOL ALTSEQ LTOU Instructs SyncSort to translate EBCDIC letters in a specified field from lowercase to uppercase. Instructs SyncSort to translate EBCDIC letters in a specified field from uppercase to lowercase.

HEX

TRAN

UTOL

ALTSEQ Instructs SyncSort to translate characters based on the ALTSEQ table in effect.

Chapter 2. SyncSort Control Statements

2.105

OUTREC
For examples of OUTREC control statements that use the TRAN subparameter, see Figure 58 on page 2.132 and Figure 59 on page 2.133. fy2f(c) Use this subparameter together with the p,l elements to indicate the conversion of a full-date field to a printable date with separator character(s). The c represents the separator and can be any character except a blank. The year portion of the date is converted to a 4-digit year using the century window defined by the CENTWIN parameter. The century window is not used for the special values, which are expanded with characters of the proper format. (See table on the next page.)

2.106

SyncSort for z/OS 1.2 Programmers Guide

OUTREC
The following table shows what is produced if (c) is set to a /: Full-Date Format Y2T Date Form yyx yyxx yyxxx yyxxxx Y2U yyx (X'yyxs') yyxxx (X'yyxxxs') Y2V yyxx (X'0yyxxs') yyxxxx (X'0yyxxxxs') Y2W xyy xxyy xxxyy xxxxyy Y2X xyy (X'xyys') xxxyy (X'xxxyys') Y2Y xxyy (X'0xxyys') xxxxyy (X'0xxxxyys') Input Length (bytes) 3 4 5 6 2 3 3 4 3 4 5 6 2 3 3 4 Output Format yyyy/x yyyy/xx yyyy/xxx yyyy/xx/xx yyyy/x yyyy/xxx yyyy/xx yyyy/xx/xx x/yyyy xx/yyyy xxx/yyyy xx/xx/yyyy x/yyyy xxx/yyyy xx/yyyy xx/xx/yyyy

Table 15. Full-Date Field Conversions

Chapter 2. SyncSort Control Statements

2.107

OUTREC
fy2fP Use this subparameter together with the p,l elements to indicate the conversion of a full-date field to a packed decimal format. The year portion of the date is converted to a 4-digit year using the century window defined by the CENTWIN parameter. The century window is not used for the special values, which are expanded with characters of the proper format. (See table on the next page.)

2.108

SyncSort for z/OS 1.2 Programmers Guide

OUTREC

Full-Date Format Y2TP

Date Form yyx yyxx yyxxx yyxxxx

Input Length (bytes) 3 4 5 6 2 3 3 4 3 4 5 6 2 3 3 4 2 1

Output Format* X'yyyyxC' X'0yyyyxxC' X'yyyyxxxC' X'0yyyyxxxxC' X'yyyyxC' X'yyyyxxxC' X'0yyyyxxC' X'0yyyyxxxxC' X'xyyyyC' X'0xxyyyyC' X'xxxyyyyC' X'0xxxxyyyyC' X'xyyyyC' X'xxxyyyyC' X'0xxyyyyC' X'0xxxxyyyyC' X'yyyy' X'yyyy'

Y2UP

yyx (X'yyxs') yyxxx (X'yyxxxs')

Y2VP

yyxx (X'0yyxxs') yyxxxx (X'0yyxxxxs')

Y2WP

xyy xxyy xxxyy xxxxyy

Y2XP

xyy (X'xyys') xxxyy (X'xxxyys')

Y2YP

xxyy (X'0xxyys') xxxxyy (X'0xxxxyys')

Y2PP Y2DP

x'dyyd' x'yy'

* 'C' is a positive sign value. Table 16. Full-Date Field Conversions for fy2fP

Chapter 2. SyncSort Control Statements

2.109

OUTREC
How to Convert Numeric Data
One of the most important functions of OUTREC processing is to convert a numeric data field or an expression to either an output numeric data format or a printable format with editing capabilities. OUTREC processing can also expand a packed decimal 2-digit year to a packed decimal 4digit year. In such cases, Y2ID or Y2IP formats are used to convert from a 2-digit to a 4digit year while maintaining a packed format. For details on converting year data, see Converting Year Data with Century Window Processing on INREC, OUTREC, or OUTFIL OUTREC on page 2.112. When a single numeric field defined by p,l,fi is to be converted to a printable format without editing, the format and length of the field determine the length of the output field, as illustrated in the following two tables. Data Conversion Input Format ZD PD BI, FI BI, FI BI, FI BI, FI CSF or FS n PD0 Y2C, Y2P, Y2S, Y2Z Y2B, Y2D Y2ID Y2IP Table 17. n 2 1 1 2 Number of Bytes in Input Field n n 1 2 3 4 n 2n-1 3 5 8 10 n (to maximum of 15, then truncated) 2n-2 digits 4 digits 4 digits 2 bytes 3 bytes Number of Resulting Digits (d)

Data Conversion Table

2.110

SyncSort for z/OS 1.2 Programmers Guide

OUTREC
For full-date formats, the number of bytes in the input field can vary. The following table shows input lengths for full-date formats and the resulting output length: Number of Bytes in Input Field 3 4 5 6 Y2U 2 3 Y2V 3 4 Y2W 3 4 5 6 Y2X 2 3 Y2Y 3 4 Number of Resulting Digits (d) 5 6 7 8 5 7 6 8 5 6 7 8 5 7 6 8

Input Format Y2T

Table 18. Data Conversion Table Full-Date Formats For any other type of expression (those that are not a simple p,l,fi), SyncSort internally treats the input field length as 15. Thus, in Table 15 and Table 17, d would be equal to 15. (For more details on expressions, see the description of expression on pages 2.87-2.89.) If you specify no other FIELDS subparameters, the result will be converted to printable output according to the default editing mask, M0. See The Mm Subparameter (Editing Masks) on page 2.121. Other forms of printable output can be created by using the EDIT, LENGTH, Mm, and SIGNS subparameters, which allow you to create your own edit patterns, or by using one of the 27 SyncSort-supplied editing masks, which are appropriate for many editing operations. To convert to a numeric data field, simply specify an output format of BI, CSF/FS, FI, PD, or ZD. The default output field length is determined by the following table, where d in the

Chapter 2. SyncSort Control Statements

2.111

OUTREC
second column is obtained from column 3 of Table 17 on page 2.110 for p,l,fi fields. For any other type of expression (not p,l,fi), d is equal to 15. Default Output Length (bytes) 4 d+1 4 d+1 d/2 + 1 d Table 19. Output Length of Output Formats

Output Format

BI CSF FI FS PD ZD

These lengths can be overridden by specifying the LENGTH parameter. The following five sections describe the data conversion capabilities: Converting Year Data with century window processing on INREC, OUTREC, or OUTFIL OUTREC The EDIT Subparameter The LENGTH=n Subparameter The Mm Subparameter (Editing Masks) The SIGNS Subparameter

Converting Year Data with Century Window Processing on INREC, OUTREC, or OUTFIL OUTREC
A 2-digit year field, as specified by the Y2B, Y2C, Y2D, Y2P, Y2S, Y2Z, Y2ID, and Y2IP formats, can be converted on output to a 4-digit year. For full-date fields, as specified by the Y2T, Y2U, Y2V, Y2W, Y2X, and Y2Y formats, the 2-digit year portion can be expanded on output to a 4-digit year. The following describes output data conversion for date fields:

2.112

SyncSort for z/OS 1.2 Programmers Guide

OUTREC
The Y2B format specifies 2-digit, 1-byte binary year data that will be converted to a 4digit, displayable character format with the appropriate century value. For information on the range of binary values representing year data with Y2B, see Table 24 on page 2.150. The Y2C and Y2Z formats specify 2-digit year data that are in displayable (zoned decimal) format. The 2-digit year data will be expanded to a 4-digit field containing the appropriate century value. The Y2S format is equivalent to Y2C and Y2Z for valid numeric year data. All three formats will convert such data to a displayable 4-digit year with the appropriate century value. Y2S, however, provides additional functionality. For data with binary zeros (X'00'), a blank (X'40') or binary ones (X'FF') in the first byte, typically to identify header/trailer records, Y2S will expand the data to 4 bytes, padded in the first 2 bytes with the same character as found in the first byte of the input field. The fourth byte of the output field is copied unchanged from the second byte of the input field. The following symbolic representation shows the treatment in hexadecimal of the three types of data: SORTIN Input 00ab 40ab FFab OUTREC Output 000000ab 404040ab FFFFFFab

The Y2D and Y2P formats specify 2-digit year values in packed decimal format. The processing applied to these fields will create a 4-digit year value converted to a displayable character format. The Y2ID and Y2IP formats take as input the same 2-digit packed decimal year data as the Y2D and Y2P formats but produce a 4-digit year output that remains in packed decimal format. Y2ID will convert data from X'yy' to X'ccyy', and Y2IP will convert data from X'ayys' to X'accyys', where cc is the correct century. (For a description of Y2D and Y2P formats for SORT or MERGE processing, see Table 24 on page 2.150 or Table 10 on page 2.51, respectively.) For full-date fields (Y2T, Y2U, Y2V, Y2W, Y2X, and Y2Y), the 2-digit portion will expand to the appropriate 4-digit year based on the CENTWIN setting. The output field length can be determined from Table 18 on page 2.111.

Note that an additional data format, PD0, which is typically used to process the month and day portion of packed decimal data, is not affected by CENTWIN processing and will not convert 2-digit year data to 4-digit years. PD0 can be used with the SyncSort-supplied edit mask M11. The year data formats Y2B, Y2C, Y2D, Y2P and Y2Z can also be used when forming expressions. The 4-digit year will be converted to an integer for arithmetic calculations. Any expression with these formats can also be converted to an output numerical data format fo, or to printable output by specifying one or more of the OUTREC FIELDS subparameters (Mm, EDIT, SIGNS or LENGTH). For information on using the year data formats

Chapter 2. SyncSort Control Statements

2.113

OUTREC
for SORT or MERGE field specifications, see CENTWIN Parameter (Optional) on page 2.149 or CENTWIN Parameter (Optional) on page 2.51, respectively. For more information on using the year data formats for INREC or OUTREC processing, see Example 5 on page 2.132. For more information on converting full-date formats, see the descriptions of the fi and fy2f,(c) parameters on pages 2.103-2.106, Table 15 on page 2.107, and Table 18 on page 2.111.

Converting SMF Date and Time Formats


You can convert SMF date and time formats to standard date and time formats. The following table shows the SMF formats and the converted output:

SMF Format DT1 DT2 DT3 TM1 TM2 TM3 TM4

Converted Output Z'yyyymmdd' Z'yyyymm' Z'yyyyddd' Z'hhmmss' Z'hhmm' Z'hh' Z'hhmmssxx'

Table 20. SMF Formats and Converted Output For DTn, the source is the 4-byte packed SMF date value (P'cyyddd'). For TMn, the source is a 4-byte binary SMF time value. The c in the date source P'cyyddd' represents the century. It is converted as follows: 0 is converted to 19, 1 is converted to 20, and 2 or greater is converted to 21. The converted output is a zoned decimal field, where each character in the table represents a single byte. For TM4, xx represents hundredths of a second. The SyncSort predefined edit masks (M0-M26) or specified edit patterns can be used to edit the converted date and time. The default mask is M11. Notes: A data exception (0C7 ABEND) or an inaccurate ZD date can occur if an SMF date is not valid. An inaccurate ZD time can occur if an SMF time is not valid. SMF dates and times are processed as positive values.

2.114

SyncSort for z/OS 1.2 Programmers Guide

OUTREC
For an example of an OUTFIL control statement that converts SMF formats, see Figure 56 on page 2.132.

Specifying Literal Fields


Spaces (X), hexadecimal digits (X'hhhh...hh'), literal strings (C'literal string'), and binary zeros (Z) can also be specified in the FIELDS parameter. Each of these entries can be preceded by an 'n' value which indicates that a specified number of spaces, hex digits, literal strings, or binary zeros should be inserted in the output record. Additionally, SEQNUM can be specified to place a sequence number field in the output record. nX Use the nX entry to specify a number n of spaces. The n value may be any number from 1 to 4095 inclusive. The X entry represents a space and must be coded to the immediate right of the number specified for n. If more than 4095 spaces are desired, two or more nX values should be specified. Use the nX'hhhh...hh' entry to specify that n copies of hex digits or hex digit strings should be inserted in the output record. (Each hh pair is 1 byte of output.) The repetition factor n may be any number from 1 to 4095 inclusive. Use the nC'literal string' entry to specify that n copies of literal strings should be inserted in the output record. The repetition factor n may be any number between 1 and 4095 inclusive. An apostrophe within a literal string must be specified with a double apostrophe (e.g., C'O''LEARY'). Use the nZ entry to define a specified number n of binary zeros that will be inserted in the output record. The repetition factor n may be any number between 1 and 4095 inclusive. The Z entry must be coded to the immediate right of n. Use SEQNUM to create a sequence number field within the output record. The length of the field can be from 1 to 16 bytes and can be represented in either BI, PD, or ZD formats. In addition, a starting value and an increment can be specified for the field. The following describes the SEQNUM variables and parameters: l Represents the length in bytes of the field to be created. A value from 1 to 16 can be specified. Indicates the format of the field to be created. BI, PD, or ZD can be specified to create an unsigned binary field, a packed decimal field, or zoned decimal field, respectively.

nX'hhhh...hh'

nC'literal string'

nZ

SEQNUM

Chapter 2. SyncSort Control Statements

2.115

OUTREC
START Optionally specifies a starting number n for the field. The n value can be 0 through 2,147,483,647. The default is 1. Optionally specifies a value i that indicates how sequence numbers should be incremented. The i value can be 1 through 65,535. The default is 1.

INCR

The maximum sequence number generated is limited to 15 decimal digits or the length of the output field. If a number is reached that would exceed the limit, SyncSort will truncate the high-order digit and continue processing. Thus, sequence numbers will cycle within the limit. For example, if the output field is 2 bytes, then 99 will be the highest sequence number. The next number, 100, will have its high-order digit truncated. The resulting number, 00, starts a new sequence number cycle from 00 to 99, regardless of the START value.

Generating Run-Time Date and Time Constants


You can insert the date and time of your SyncSort run into your records. The following table shows the constants generated by the run-time date and time parameters. A 'C' in the output format denotes a character constant, while a 'P' denotes a packed decimal constant. Packed decimal constants contain a positive sign and a leading zero when padding is necessary. A '(c)' in the parameter represents a separator character. A blank used as the separator character must be enclosed in apostrophes. An apostrophe used as the separator character must be specified as two apostrophes enclosed within apostrophes ('''').

2.116

SyncSort for z/OS 1.2 Programmers Guide

OUTREC

Parameter &DATE &DATE1 &DATE1(c) &DATE1P &DATE2 &DATE2(c) &DATE2P &DATE3 &DATE3(c) &DATE3P &DATE4 &DATE=(m1m2m3m4) &DATENS=(xyz) &TIME &TIME1 &TIME1(c) &TIME1P &TIME2 &TIME2(c) &TIME2P &TIME3 &TIME3P &TIME=(hp) &TIMENS=(tt) C'mm/dd/yy'

Output

Length (Bytes) 8 8 10 5 6 7 4 7 8 4 19

C'yyyymmdd' C'yyyycmmcdd' P'yyyymmdd' C'yyyymm' C'yyyycmm' P'yyyymm' C'yyyyddd' C'yyyycddd' P'yyyyddd' C'yyyy-mm-dd-hh.mm.ss' (see description below table) (see description below table) C'hh:mm:ss' C'hhmmss' C'hhcmmcss' P'hhmmss' C'hhmm' C'hhcmm' P'hhmm' C'hh' P'hh' (see description below table) (see description below table) Table 21. Run Time Constants

8 6 8 4 4 5 3 2 2

Chapter 2. SyncSort Control Statements

2.117

OUTREC

&DATE=(m1m2m3m4) This form of the &DATE subparameter generates the current system date and controls the formatting of the date. You can specify the position of the year, month, and date; specify a separator character; and choose between 2-digit and 4-digit year representation. The positions m1 through m4 represent masks used to format the date. To specify the positions of the month, day, and year, replace the m1, m2 and m3 positions, in any order, with M for the month (01-12), D for the day (01-31), and either Y or 4 for the year (where Y is a 2digit year and 4 is a 4-digit year). Replace the m4 position with a separator character. For example, to print the date with the form yy-mm-dd, specify &DATE=(YMD-). For December 31, 1997, the date would appear as 97-12-31. A blank used as the separator character must be enclosed in apostrophes. An apostrophe used as the separator character must be specified as two apostrophes enclosed within apostrophes (''''). The field for this form of &DATE requires 8 bytes for a 2-digit year representation and 10 bytes for a 4-digit year. The M, D, and Y or 4 may only appear once in the mask. All four positions must be specified. &DATENS=(xyz) specifies that the current date is to appear in the output record in the form 'xyz', where x, y, and z indicate the order in which the month, day, and year are to appear and whether the year is to appear as two or four digits. For x, y, and z, use M to represent the month (01-12), D to represent the day (01-31), Y to represent the last two digits of the year (for example, 02), or 4 to represent the four digits of the year (for example, 2002). M, D, and Y or 4 can each be specified only once. For example, &DATENS=(DMY) would produce a date of the form 'ddmmyy' which on March 29, 2002, would appear as '290302'. &DATENS=(4MD) would produce a date of the form 'yyyymmdd' which on March 29, 2002, would appear as '20020329'. x, y, and z must be specified. &TIME=(hp) This form of the &TIME subparameter generates the current system time of day and controls the formatting of the time. You can print the time in 24-hour or 12-hour formats and specify the separator character between the hours, minutes and seconds. The format for 24-hour time is hhpmmpss, where hh represents the hour (00-23), mm represents minutes (00-59), ss represents seconds (00-59), and p represents the separator character as specified by p in the &TIME=(hp) subparameter. The format for 12-hour time is hhpmmpss nn, where hh represents the hour (01-12), mm represents minutes (00-59), ss represents seconds (00-59), and p represents the separator character as specified by p in the &TIME=(hp) subparameter. The nn is am or pm as appropriate.

2.118

SyncSort for z/OS 1.2 Programmers Guide

OUTREC
To select 12-hour mode specify h as 12; to select 24-hour mode specify h as 24. The p specification represents the character to use as a separator. For example, to display the time in a 12-hour format with a period as a separator, specify &TIME=(12.). At 22:43:23 hours, the time would appear as 10.43.23 pm. A blank used as the separator character must be enclosed in apostrophes. An apostrophe used as the separator character must be specified as two apostrophes enclosed within apostrophes (''''). The field for this form of the &TIME subparameter requires 8 bytes for the 24-hour format and 11 bytes for the 12-hour format. &TIMENS=(tt) specifies that the current time is to appear in the output record in the form 'hhmmss' (24-hour time) or 'hhmmss xx' (12-hour time). If tt is 24, the time is to appear in the form 'hhmmss' (24-hour time) where hh represents the hour (00-23), mm represents the minutes (00-59), and ss represents the seconds (00-59). For example, &TIMENS=(24) would produce a time of the form 'hhmmss' which at 08:25:13 pm would appear as '202513'. If tt is 12, the time is to appear in the form 'hhmmss xx' (12hour time) where hh represents the hour (01-12), mm represents the minutes (00-59), ss represents the seconds (00-59), and xx is either 'am' or 'pm'. For a second example, &TIMENS=(12) would produce a time of the form 'hhmmss xx' which at 08:25:13 pm would appear as '082513 pm'. For an example of an OUTREC control statement that generates run-time constants, see Figure 57 on page 2.132.

The EDIT Subparameter


The EDIT parameter lets you create your own edit patterns for converted numeric data. An edit pattern can consist of: Significant digit selectors. Leading insignificant digit selectors. Sign replacement characters. Any other characters to be printed in the actual output.

The edit pattern can be up to 22 characters in length, with a maximum of 15 digits. The characters used to represent significant or insignificant digit selectors are determined by the keyword EDIT. If EDIT is specified, the letter I represents leading insignificant digits which will print as blanks if the digits are zeros, and the letter T represents significant digits (digits that will print in their true form, even as leading zeros).

Chapter 2. SyncSort Control Statements

2.119

OUTREC
The keyword EDIT can be specified with replacements for the letters I and/or T. Any printable character can be used as a replacement character. This replacement makes available to the user a pattern which encompasses all printable characters. The figure below illustrates the concept of replacing the insignificant and significant digit selectors I and T with other characters.

EDxy= where: x = insignificant digit selector y = insignificant digit selector Figure 48. Replacing Digit Selector Characters When a blank, quotation mark or unbalanced parenthesis appears within an EDIT pattern, the entire pattern must be enclosed within single quotation marks. Balanced parentheses need not be enclosed within quotation marks. A single quotation mark within the pattern (i.e., an apostrophe) must be specified as two apostrophes. All other characters are printed as specified in the edit pattern, with the following exceptions: Any character specified after the first leading insignificant digit selector and before the first significant digit selector will print as a blank, unless a previously selected digit was non-zero. Any character specified after the last significant digit selector will print as a blank if the edited number is positive. Any character or character string specified before the first leading insignificant digit selector, including a leading sign character, will print to the immediate left of the first significant digit. The appropriate number of leading blanks will be supplied, assuring that the total number of characters in the printed field corresponds to the total number of characters in the edit pattern. Any leading insignificant digit selector specified after the first significant digit selector will be treated as a significant digit selector. The sign replacement character appearing as the first and/or last character of the pattern is replaced as per the SIGNS subparameter.

The LENGTH=n Subparameter


Use the LENGTH=n parameter to alter the default length of the output field data. The maximum value which can be specified for n is 22.

2.120

SyncSort for z/OS 1.2 Programmers Guide

OUTREC
When an editing mask is used, the default length is determined by the edit pattern and the format of the field. If LENGTH=n is not specified, the length is equal to the number of characters specified in the edit pattern. If LENGTH=n is specified, the edit pattern will either be truncated on the left or padded with blanks on the left so that the length of the pattern equals the n value. When an output data format fo is used, the default length is 4 for BI and FI formats, and is determined by the number of digits in the input expression for CFS/FS, PD and ZD formats. (The number of digits is 15 for any input expression other than a single p,l,fi field.) If LENGTH=n is specified, the output data will either be truncated on the left or padded on the left with zeros (or blanks for CSF/FS) of the appropriate format to a length of n.

The Mm Subparameter (Editing Masks)


SyncSort for z/OS provides editing masks to simplify the more common editing operations. If neither Mm nor EDIT is specified in the OUTREC control statement, M0 is used to edit BI, FI, PD, PD0, ZD, and CSF/FS fields and M11 is used to edit DT1, DT2, DT3, TM1, TM2, TM3, and TM4 fields.

Chapter 2. SyncSort Control Statements

2.121

OUTREC

Mask M0 M1 M2 M3 M4 M5 M6 M7 M8 M9 M10 M11 M12 M13 M14 M15 M16 M17 M18

Pattern IIIIIIIIIIIIIITS TTTTTTTTTTTTTTTS I,III,III,III,IIT.TTS I,III,III,III,IIT.TTCR SI,III,III,III,IIT.TT SI,III,III,III,IIT.TTS III-TTT-TTTT TTT-TT-TTTT IT:TT:TT IT/TT/TT IIIIIIIIIIIIIIT TTTTTTTTTTTTTTT SIII,III,III,III,IIT SIII.III.III.III.IIT SIII III III III IITS III III III III IITS SIII III III III IIT SIII'III'III'III'IIT SI,III,III,III,IIT.TT (+,-)

Signs (,,' ',-) (,,' ',-) (,,' ',-) d+1 d+1

Length

d+1 + [d/3] d+2 + [d/3] d+1 + [d/3] d+2 + [d/3] 12 11 8 8 d d

(' ',(,' ',))

(' ',-) (' ',-) (' ',(,' ',)) (,,' ',-) (' ',-) (' ',-) (' ',-)

d+1 + [(d-1)/3] d+1 + [(d-1)/3] d+2 + [(d-1)/3] d+1 + [(d-1)/3] d+1 + [(d-1)/3] d+1 + [(d-1)/3] d+1 + [d/3]

Table 22. (Page 1 of 2) Editing Masks

2.122

SyncSort for z/OS 1.2 Programmers Guide

OUTREC
Mask M19 M20 M21 M22 M23 M24 M25 M26 Pattern SI.III.III.III.IIT,TT SI III III III IIT,TTS I III III III IIT,TTS SI III III III IIT,TT SI'III'III'III'IIT.TT SI'III'III'III'IIT,TT SIIIIIIIIIIIIIIT STTTTTTTTTTTTTTT Signs (' ',-) (' ',(,' ',)) (,,' ',-) (' ',-) (' ',-) (' ',-) (' ',-) (+,-) Length d+1 + [d/3] d+2 + [d/3] d+1 + [d/3] d+1 + [d/3] d+1 + [d/3] d+1 + [d/3] d+1 d+1

Table 22. (Page 2 of 2) Editing Masks Notes: M0 is the default mask The letter d represents the number of resulting digits after data conversion. The mask patterns in the Pattern column show the maximum number of resulting digits, which is 15. (Refer to Table 17 on page 2.110.) The bracket symbols indicate that only the integer part of this division should be retained.

The Editing Masks table illustrates the following for each of the available masks. Edit pattern. Leading or trailing signs, where appropriate. Length. If a SyncSort editing mask is used for totaled or subtotaled data, the length of the output field is determined by the maximum permissible length of the data format, not by the specified length of the input field. The subparameter LENGTH can be used to override the length of the output field.

The edit patterns use the same symbolic letters used in the EDIT subparameter. Leading insignificant digits are represented by the letter I; significant digits are represented by the

Chapter 2. SyncSort Control Statements

2.123

OUTREC
letter T. Leading or trailing sign replacement characters are represented by the letter S. All other characters print as they appear in the pattern. The SIGNS illustrated for each mask follow the format requirements of the SIGNS subparameter. You can specify the SIGNS subparameter to selectively override the signs for a particular mask. For example, if you specify mask M4 and also specify SIGNS=(' '), a leading blank will print instead of a plus sign if the number is positive. However, a leading minus sign will print if the number is negative because the leading negative sign specified in the editing mask has not been overridden. The lengths in the table represent the length, in bytes, of the mask. The lengths of masks M0-M5 and M10-M26 are determined, in part, by the number of digits d. Refer to Table 17 on page 2.110 to determine the number of digits for each type of numeric field.

The SIGNS Subparameter


The SIGNS subparameter specifies the sign(s) that will appear before or after the edited number. The sign replacement character, normally 'S', has special meaning if it appears as the first or last character in an edit pattern. In these positions, the sign replacement character will be replaced, as appropriate, by the characters specified by the SIGNS subparameter. The format of the SIGNS subparameter is illustrated below.

SIGNS=(s1,s2,s3,s4) where: s1= leading positive sign indicator s2= leading negative sign indicator s3= trailing positive sign indicator s4= trailing negative sign indicator Because the SIGNS subparameter contains four positional values, commas must be used to indicate embedded, unspecified values. Each of the four values can contain one, and only one, character; specified characters must be separated by commas. A blank, comma, quotation mark and unbalanced parenthesis used as a SIGNS character must be enclosed within apostrophes. An apostrophe used as a SIGNS character must be specified as two apostrophes enclosed within apostrophes ('''').

2.124

SyncSort for z/OS 1.2 Programmers Guide

OUTREC
When the SIGNS subparameter is specified, the letter 'S' is normally used as the sign replacement character in the user-supplied edit pattern. The user can change the last letter of the keyword SIGNS in order to specify another character as the sign replacement character. For example, if the user specifies SIGNX instead of SIGNS, the letter 'X' becomes the sign replacement character in the user-provided edit pattern. If the user specifies a sign replacement character in the edit pattern but does not specify a value in the corresponding position in the SIGNS parameter, a blank will be assumed. For example, if the user specifies the following:

EDIT=(IITT.TTS),SIGNS=(,,,-) then a trailing minus sign will print if the number is negative and a trailing blank will print if the number is positive. The SIGNS subparameter can also be used to override the sign values in SyncSort-provided editing masks.

The CHANGE Subparameter


The CHANGE subparameter changes an input field to a replacement constant in the reformatted output record if the input field equals a search constant. The input field remains unchanged on the input side. The format of the CHANGE subparameter is shown below:

[c:] p,l, CHANGE=(o,srch 1 ,repl 1 [,srch 2 ,repl 2 ,...srch n, repl n ] ) nmrepl ,NOMATCH=( ) r,n

Figure 49. Change Subparameter Multiple search-replacement paired constants, with different data formats, can be specified on a CHANGE subparameter. Note the following rules for mixing data formats: Search constants are character, hexadecimal, or binary strings. Multiple search constants on a CHANGE subparameter can be a mixture of character and hexadecimal formats. Binary search constants cannot be mixed with search constants of other formats; thus, if one search constant on a CHANGE subparameter is binary, all other search constants on that subparameter must also be binary.

Chapter 2. SyncSort Control Statements

2.125

OUTREC
Replacement constants are character or hexadecimal strings. Multiple replacement constants on a CHANGE subparameter can be a mixture of character and hexadecimal data formats. The constants of a search-replacement pair can be of different data format. For example, a hexadecimal or binary search constant could be paired with a character replacement constant, or a character search constant could be paired with a hexadecimal replacement constant. Thus, you could change a hexadecimal or binary input field to a character output field, or you could change a character input field to a hexadecimal output field.

The following describes the elements of the CHANGE subparameter: p,l The normal SyncSort position-length designation that specifies the input field. When this field matches a search constant, the field will be changed in the output to a replacement constant. For character or hexadecimal search constants, the input field can be 1 to 64 bytes long. For binary search constants, the input field must be one byte. o The length of the output replacement field. Permissible length is 1 to 64 bytes. The search constant to which the input field is compared. Permissible formats are character string (C'x...x'), hexadecimal string (X'x...x'), or a binary byte (B'bbbbbbbb'). When the search constant matches the input field, the input field will be changed to an output replacement constant. If one of the search constants is binary in a set of search-replacement pairs on a CHANGE subparameter, then all the search constants on that CHANGE subparameter must be binary. (For additional information on using binary fields in INCLUDE/OMIT processing, see INCLUDE/OMIT Control Statement on page 2.19.) If the search constant is longer than the length l of the input field, the constant will be truncated to length l. If the search constant is shorter than l, the constant will be padded on the right to length l. Character strings are padded with blanks (X'40'). Hexadecimal strings are padded with zeros (X'00'). Binary strings are neither truncated nor padded since only one-byte strings are permissible. repl The replacement constant to which the input field is changed in the reformatted output record when the input field matches a search constant. Permissible formats are character string (C'x...x') and hexadecimal string (X'x...x'). If the replacement constant is longer than the length o of the output field, the constant will be truncated to length o. If the replacement constant is

srch

2.126

SyncSort for z/OS 1.2 Programmers Guide

OUTREC
shorter than o, the constant will be padded on the right to length o. Character strings are padded with blanks (X'40'). Hexadecimal strings are padded with zeros (X'00'). NOMATCH Indicates how SyncSort should respond if the input field does not match a search constant. If NOMATCH is not specified and no search constant matches the input field, sort processing will terminate with an error message. A replacement constant to which the input field is changed in the reformatted output record when the input field p,l fails to match a search constant. For details, see the description of the repl variable above. The position r and length n of an input field that will be inserted in the output record when the CHANGE input field p,l fails to match a search constant. n must be at least 1. If n is greater than the length o specified for the output replacement field, the output field r,n will be truncated on the right to length o. If n is less than o, the field r,n will be padded on the right with blanks (X'40') to the length o. The following example illustrates the use of the CHANGE subparameter:

nmrepl

r,n

OUTREC FIELDS=(16,2, CHANGE=(13,C'NJ',C'NEW JERSEY', C'NY',C'NEW YORK', C'PA',C'PENNSYLVANIA'), NOMATCH=(C'NOT SUPPORTED'), 8X, 24,1, CHANGE=(10,B'1.......',C'EAST COAST', B'0.......',C'WEST COAST')) Figure 50. Sample OUTREC Parameter with CHANGE Subparameter In the above example, the FIELDS parameter contains two CHANGE subparameters. The first CHANGE subparameter changes the input field 16,2 to a state name in the reformatted output record when the input field matches a state code. If no matches are found, the output field will be 'NOT SUPPORTED.' The second change subparameter changes the onebyte input field 24,1 to 'EAST COAST' or 'WEST COAST' in the reformatted output record, depending on the binary contents of the input field. The following example illustrates a situation that can arise when using binary search constants. In such cases, more than one search constant may match an input field:

Chapter 2. SyncSort Control Statements

2.127

OUTREC

OUTREC FIELDS=(24,1, CHANGE=(6,B'.....11.',C'SHARE', B'......1.',C'UNIQUE')) Figure 51. CHANGE Subparameter with Binary Search Constants

Note that in the above example, the input field X'06' would match both binary search constants. In such cases, the first search constant is used, thus the output would be the character string 'SHARE'. If the input field were X'02', the output would be the character string 'UNIQUE'.

CONVERT Parameter (Optional)


The CONVERT parameter enables you to convert variable-length records into fixed-length records. These records do not require an RDW and will be written to any output file(s) with a RECFM of F or FB. When using CONVERT, you no longer need to apply the rules for Specifying the FIELDS parameter for Variable-Length Records. You cannot specify the variable portion of the input records (position without length) when using CONVERT. However, all data fields need not be present in each record being CONVERTed, unless a numeric or year data field is specified. That is, blanks will be used as a default for any missing p,l field bytes, while all p,l,f fields must be present. When using CONVERT in conjunction with the OUTREC parameter on the OUTFIL control statement, data fields of any type need not be present, and you may change the default padding character with the VLFILL parameter. (See the explanations of CONVERT and VLFILL in the OUTFIL control statement section.) You may also create multiple output files with different record formats when specifying CONVERT on the OUTFIL control statement.

Sample OUTREC Control Statements


Example 1 The following example illustrates how the OUTREC control statement can be used to insert binary zeros and blanks into the record.

OUTREC FIELDS=(1:4Z,5:20,10,23:44,28,10X) Figure 52. Example 1, Sample OUTREC Control Statement

2.128

SyncSort for z/OS 1.2 Programmers Guide

OUTREC
This OUTREC control statement defines a 60-byte record as follows: Four binary zeros are inserted in the first 4 bytes of the record (4Z). The next field begins in position 5. This field began in position 20 before OUTREC processing and is 10 bytes long (5:20,10). Eight blanks are inserted before the next field, which is positioned at byte 23. SyncSort for z/OS automatically inserts blanks in the unused positions between fields. The next field begins in position 23. This field began in position 44 before OUTREC processing and is 28 bytes long (23:44,28). Ten blanks are inserted in the last 10 bytes of the record (10X).

Example 2 The following example illustrates how the OUTREC control statement can be used to convert and edit numeric fields.

OUTREC FIELDS=(1,50,64,4,PD,M2,68,6,ZD, EDIT=($I,IIT.TTS),SIGNS=(,,+,-)) Figure 53. Example 2, Sample OUTREC Control Statement This OUTREC control statement defines a 70-byte output record as follows: The first field (1,50) begins in position 1. This field began in position 1 before OUTREC processing and is 50 bytes long. The next field (64,4) begins in position 51. This packed decimal field began in position 64 before OUTREC processing and is 4 bytes long. After being converted and edited by editing mask M2 (64,4,PD,M2) the resulting field will be 10 bytes long. However, the number of digits that will actually print will depend on the number of leading zeros, if any, because this mask specifies that only three digits must print whether or not they are leading zeros. Moreover, this mask specifies that a minus sign print after the number if it is negative and a blank print after the number if it is positive. The last field (68,6) begins in position 61. This zoned decimal field began in position 68 before OUTREC processing and is 6 bytes long. The EDIT and SIGNS subparameters (EDIT=($I,IIT.TTS),SIGNS=(,,+,-)) specify a 10-byte field because 4 additional bytes are needed for the dollar sign, the comma, the decimal point and the trailing plus or minus sign. Note that if the first three digits are leading zeros, they will be suppressed.

Chapter 2. SyncSort Control Statements

2.129

OUTREC
Example 3 This example uses the OUTREC control statement to convert numeric data from one format to another.

OUTREC FIELDS=(1,10,ZD,PD, 11,4,FI,ZD,LENGTH=8) Figure 54. Example 3, Sample OUTREC Control Statement This OUTREC control statement defines a 14-byte output record as follows: The first field (1,10,ZD,PD) begins in position 1. This field was a 10-byte ZD field that began in position 1 before OUTREC processing. It will be converted to a 6-byte PD field in the output record, because 6 bytes are required to contain 10 decimal digits as a PD field. The next field (11,4,FI,ZD) begins in position 7. This field was a 4-byte FI field that began in position 11 before OUTREC processing. It will be converted to an 8-byte ZD field in the output record. Normally 10 ZD bytes would be required to contain the 10 decimal digits that may be represented by a 4-byte FI field, but the LENGTH=8 parameter overrode the output length. If there are more than 8 decimal digits in any of the 11,4,FI fields, those digits will be truncated on the left in the output record. Note that ZD output is not the same as printable output using editing masks. High order zeros will appear as zeros in a ZD field, while they appear as blanks when using the default M0 mask, as well as most other masks. The sign indicator in a ZD field is placed in the first 4 bits of the rightmost byte, and not as a separate printable sign. Example 4 This OUTREC example uses arithmetic and function operators to do algebraic calculations. New 8-byte PD fields are required in each record containing the maximum and average of fields A, B and C. Another new 5-byte printable field is required containing field D as a percentage of field E. The field definitions are: Field A: Field B: Field C: Field D: Field E: 1,4,PD 5,8,ZD 13,4,FI 25,4,PD 29,4,PD

The OUTREC control statement to accomplish this would be:

2.130

SyncSort for z/OS 1.2 Programmers Guide

OUTREC

OUTREC FIELDS=(1,36, 40:(01,4,PD,ADD, 05,8,ZD,ADD, 13,4,FI), DIV,+3, PD, * 50:01,4,PD,MAX, 05,8,ZD,MAX, 13,4,FI, PD, * 60:+100,MUL, 25,4,PD,DIV, 29,4,PD, LENGTH=5) *

Retain existing fields Field A plus Field B plus Field C divide by 3 to get average output as 8-byte PD field Determine maximum of Field A and Field B and Field C output as 8-byte PD field 100 times Field D divided by Field E output as printable 5-byte field using default M0 mask

Figure 55. Example 4, Sample OUTREC Control Statement This OUTREC control statement defines a 64-byte output record as follows: The first field (1,36) retains the complete contents of the input record. The second output field begins in position 40. An arithmetic calculation is done using three different numeric input fields and the constant +3 to compute the arithmetic average. This is an expression that is considered to contain 15 decimal digits. The output is requested as a PD field. The length of this field will be 8 bytes, since that is the length required to contain 15 decimal digits. The third output field begins in position 50. Multiplying numeric Field D by 100 before dividing by numeric Field E gives the desired percentage number, which is considered to contain 15 decimal digits. No output format or editing mask is specified, so the default mask M0 is used to create printable output. LENGTH=5 is specified to reduce the default length of the output field from 16 to 5, since it is known that the percentage number will not be large.

Chapter 2. SyncSort Control Statements

2.131

OUTREC
Example 5 This OUTREC control statement uses DT1, TM1, and edit masks to convert SMF date and time values to appropriate formats. OUTREC FIELDS=(1,4,DT1,EDIT=(TTTT/TT/TT), 3X,5,4,TM1,EDIT=(TT:TT:TT)) Figure 56. Sample OUTREC Control Statement The following shows how the output would be formatted: 2002/07/04 2002/07/04 2002/07/05 2002/07/05 Example 6 This OUTREC control statement illustrates the use of the &DATE1(c) and &TIME1(c) parameters in a SyncSort run on June 9, 2002 at 04:16:29 p.m. OUTREC FIELDS=(8,20,24:&DATE1(' '),X,&TIME1(:)) Figure 57. Sample OUTREC Control Statement The output would include data from the input record in the first twenty columns followed by the run-time date and time starting in column 24. The date and time would appear as '2002 06 09 16:16:29'. Example 7 The following control statements illustrate two of the options of the TRAN subparameter. This OUTREC control statement uses TRAN=LTOU to translate the letters in positions 1-5 of each output record from lowercase to uppercase. OUTREC FIELDS=(1,5,TRAN=LTOU) 07:22:12 05:15:25 11:37:39 16:42:28

Figure 58. Sample OUTREC Control Statement For example, 'Ab,Cd' would translate to 'AB,CD'.

2.132

SyncSort for z/OS 1.2 Programmers Guide

OUTREC
This OUTREC control statement uses TRAN=ALTSEQ to translate each binary zero (X'00') in columns 1-5 to an asterisk (X'5C') in positions 1-5. ALTSEQ CODE=(005C) OUTREC FIELDS=(1,5,TRAN=ALTSEQ) Figure 59. Sample OUTREC Control Statement Comprehensive examples illustrating the OUTREC control statement and the OUTREC parameter of the OUTFIL control statement are provided in Chapter 3.How to Use SyncSorts Data Utility Features.

Sample OUTREC Control Statements with CENTWIN Processing


For century window processing, data conversion is determined by the century window defined by the CENTWIN parameter. The following provides examples of data conversion with CENTWIN: Example 1 A 2-digit year field in character format at position 20 in the input record could be expanded with the following specification:

OUTREC FIELDS=(1,19, * Copies first 19 bytes of record 20,2,Y2C, * Converts 2-digit year data to 4-digit year 22,59) * Copies remaining 59 bytes

Figure 60. Example 1, OUTREC Control Statement with Year Data Note that the expansion of the year data from 2 to 4 digits increases the output record length by 2 bytes compared to the input record length. The CENTWIN setting determines the century of the 2-digit year field. If CENTWIN=1980, then a year field in the input record would be converted as follows: SORTIN Input 13 79 80 92 Example 2 Consider the following packed decimal date field at position 20 in the input record: yymmdd = X'0yymmddC' OUTREC Output 2013 2079 1980 1992

Chapter 2. SyncSort Control Statements

2.133

OUTREC
Suppose you want to output a displayable 4-digit year in character format in the form mm/dd/yyyy To accomplish this, specify the following OUTREC control statement:

OUTREC FIELDS=(1,19, 21,2,PD0,M11, C'/', 22,2,PD0,M11, C'/', 20,2,Y2P, 24,76)

* * * * * * *

Copies first portion of record Converts X'ymmd' to X'mm' then C'mm' Inserts slash Converts X'mddC' to X'dd'then C'dd' Inserts slash Converts X'0yym' to X'yy' then C'yyyy' Copies rest of record

Figure 61. Example 2, OUTREC Control Statement with Year Data The 4-digit year output from the input year field (20,2,Y2P) depends on the CENTWIN setting. The following sample of input and output data shows the case for CENTWIN=1980: SORTIN Input Date Field X'0800329C' X'0790603C' Example 3 To expand a 3-byte packed decimal date field of the form X'yyddds', at position 20 in the input record, to a 4-byte packed field of the form X'yyyyddds' that contains a prefixed century value, specify an OUTREC control statement such as the following: OUTREC Output Date Field 03/29/1980 06/03/2079

OUTREC FIELDS=(1,19, 20,1,Y2ID, 21,60) *

* Copies first portion of record * Converts X'yy' to X'yyyy' * Copies rest of record starting with the X'ddds' of the date field

Figure 62. Example 3, OUTREC Control Statement with Year Data Note that in the above example the output record length will be 1 byte larger than the input record length. The following sample of input and output data shows the effect for CENTWIN=1980: SORTIN Input Date Field X'79' X'80' OUTREC Output Date Field X'2079' X'1980'

2.134

SyncSort for z/OS 1.2 Programmers Guide

OUTREC
Example 4 To expand a 4-byte packed decimal date field of the form X'0yymmdds', at position 20 in the input record, to a 5-byte field of the form X'0yyyymmdds' that contains a prefixed century value, specify an OUTREC control statement such as the following:

OUTREC FIELDS=(1,19, 20,2,Y2IP, 22,59) *

* * * *

Copies first portion of record Converts X'0yym' to X'0yyyym' Copies rest of record starting with the X'mdds' of the date field

Figure 63. Example 4, OUTREC Control Statement with Year Data As with Y2ID conversion, the output record length will be 1 byte larger than the input length. The following sample of input and output data shows the effect for CENTWIN=1980: SORTIN Input Date Field X'0790' X'0801' Example 5 Consider a 2-byte character or zoned decimal field that may contain either valid numeric year data or characters that identify the record as a header or trailer. Header records in the example are identified by zeros (X'00') or a blank (X'40') in the first byte of the year field, while trailer records are identified by binary ones (X'FF') in the first byte of the field. The Y2S format will treat the valid year data normally, in the same way as the Y2C or Y2Z formats would treat the data, but the year fields of header and trailer records will be converted to a 4-digit form padded on the left with data identical to the data in the first byte of the input field. Typically this type of conversion is needed when a Y2S SORT or MERGE field is used to collate the records so that header/trailer records in the output remain at the start or end of the file. An OUTREC control statement such as the following could be used. OUTREC Output Date Field X'020790' X'019801'

OUTREC FIELDS=(1,19, * Copies first portion of record 20,2,Y2S, * Converts C'yy' to C'yyyy' and pads * fields that identify header/trailer records 22,59) * Copies the remaining fields

Figure 64. Example 5, OUTREC Control Statement with Year Data As with Y2C or Y2Z, the output record length will be 2 bytes larger than the input record length. For CENTWIN=1990, the sorted Y2S field would be converted as follows:

Chapter 2. SyncSort Control Statements

2.135

OUTREC
SORTIN Input Date Field X'4001' X'F9F8' X'F0F3' X'0000' X'FFFF' OUTREC Output Date Field X'00000000' (from 4th X'40404001' (from 1st X'F1F9F9F8' (from 2nd X'F2F0F0F3' (from 3rd X'FFFFFFFF' (from 5th

input input input input input

record) record) record) record) record)

2.136

SyncSort for z/OS 1.2 Programmers Guide

RECORD RECORD Control Statement


The RECORD control statement provides record length and format information. It is required in the following situations: SyncSort is invoked by a program passing either a 24-bit or 31-bit extended parameter list and using an in-memory E15 or E32 exit routine. An E15 or E35 exit routine changes the record length.

RECORD Control Statement Format


The format of the RECORD control statement is illustrated below:

F RECORD TYPE= [,LENGTH=(l 1 ,l 2 ,l 3 ,l 4 ,l 5 ,l 6 ,l 7 )] V

Figure 65. RECORD Control Statement Format

TYPE Parameter (Optional)


The TYPE parameter can be used to indicate the record format. TYPE=F indicates fixedlength records; TYPE=V indicates variable-length records. TYPE=FB or TYPE=VB can be specified but the 'B' is ignored. TYPE should be specified if SORTIN is VSAM. If TYPE is not provided, the SORTOUT RECFM will be examined to determine the SORTIN TYPE. If no SORTOUT RECFM is found, TYPE=V will be assumed if SORTOUT is VSAM and TYPE=F if there is no SORTOUT or SORTOUT is non-VSAM. Note: If the TYPE specification differs from the RECFM DCB parameter for the SORTIN/ SORTINnn DD statement, the latter takes precedence.

LENGTH Parameter (Conditionally Required)


The LENGTH parameter, usually optional, is required whenever the RECORD control statement is required. The LENGTH parameter specifies the length of the record at various points during the processing of the application. The number of length values can vary from 1 to 7. Only the l1, l2 and l3 values should be specified for fixed-length records and for merge or copy applications. All seven length values can be specified for variable-length sorts. If l1 is the only value specified, parentheses

Chapter 2. SyncSort Control Statements

2.137

RECORD
are optional. If l1 and additional length values are specified, they all must be enclosed in parentheses. The length values are positionally dependent. An extra comma must indicate a missing length value between any two that are specified. Commas need not follow the final length value specified. For example, if LENGTH=(l1,,,l4) is specified, the omitted values are understood to be l2 and l3. The l1,...,l7 variables specify the following: l1 The maximum record input length of the logical records. For variablelength records, this is the length of the longest logical record plus the 4-byte Record Descriptor Word. The 4-byte RDW must be included, even if the input is a VSAM file. The maximum record length cannot exceed 32,760 for fixed-length records and 32,767 for variable-length records. An LRECL value specified on the SORTIN/SORTINnn DD statement or the data set label will override the l1 value for fixed-length records. For variable-length records, the higher value (LRECL or l1) is used. This is ignored in a join application. The maximum length of the logical records after E15 processing. An omitted l2 value defaults to the l1 value and indicates that the maximum record length has not been changed by an E15 exit. If there is no E15 exit, an l2 value which is smaller than the l1 value or the LRECL specified on the SORTIN/SORTINnn DD statement or data set label will truncate the records. This truncation will occur after the record is read from SORTIN. This is ignored in a join application. The maximum length of the logical records after E35 processing. If the l3 value is omitted, the default is either the l2 value, or, if an INREC and/or OUTREC control statement is specified, the record length after INREC/ OUTREC processing. Note that it is not necessary to specify an l3 value to reflect a length change due to INREC or OUTREC processing; the revised record length is calculated automatically. However, it is necessary to specify an l3 value if exit E35 has altered the record length. The LRECL value specified in the SORTOUT DD statement should either correspond to the l3 value or the LRECL specification should be omitted. In the latter case, SyncSort will automatically calculate the correct LRECL value. The l3 value is ignored if there is no E35 exit, so it is not possible to use the l3 value to truncate or pad the records. l4 The minimum length of the variable-length logical records plus the 4-byte Record Descriptor Word. An omitted l4 value defaults to the length from the

l2

l3

2.138

SyncSort for z/OS 1.2 Programmers Guide

RECORD
beginning of the record to the end of the last field referenced by any control statement. l5 The most frequent record length of the variable-length records. Specify this length value to optimize the size of the segment, i.e., the fixed-length block of main storage, used to contain variable-length records. The average work space required by each record, as reported by the HISTOGRM utility program. The l6 value will be ignored for a Tape Sort. The segment length recommended by the HISTOGRM utility program. If l7 is omitted, the SIZE parameter on the SORT control statement may be used to determine the impact of segment size on sort performance. Assuming the SIZE parameter reports a SORTIN data set of at least 10,000 records, SyncSort may sample the first 100-200 records to calculate an approximate segment size. An installation may decide to allow record sampling for smaller files. The l7 value will be ignored for a Tape Sort.

l6

l7

Rules for Specifying the Length Parameter


Observe the following rules when specifying length values: All length values for variable-length records must include 4 bytes for the Record Descriptor Word. The l1, l2, and l3 values must represent the maximum record lengths and the l4 value must represent the minimum record length. If SyncSort encounters a record which exceeds the maximum length or is shorter than the minimum length, the application will either terminate abnormally or produce unpredictable results.

Sample RECORD Control Statement


RECORD TYPE=F,LENGTH=(80,,60) Figure 66. Sample RECORD Control Statement This sample RECORD control statement defines the record as follows: The file contains fixed-length records. The input record length (l1) is 80 bytes. A comma represents the omitted l2 value because an E15 exit does not change the record length.

Chapter 2. SyncSort Control Statements

2.139

RECORD
The record length after INREC/OUTREC and/or E35 processing is 60 bytes. The SORTOUT LRECL should either be specified as 60 or omitted. If it is omitted, SyncSort will automatically supply the correct value.

RECORD TYPE=V,LENGTH=(400,300,250,l20,200,280,230) Figure 67. Sample RECORD Control Statement This sample RECORD control statement defines the record as follows: The file contains variable-length records. All length values include 4 bytes for the Record Descriptor Word. The maximum input record length is 400 bytes. The maximum record length after E15 processing is 300 bytes. The maximum record length after INREC/OUTREC and/or E35 processing is 250 bytes. The minimum record length is 120 bytes. The most frequent record length is 200 bytes. The average work space required for each record is 280 bytes, as reported by the HISTOGRM utility program. The segment length recommended by HISTOGRM is 230 bytes.

In the above example, the l4, l5, l6 and l7 values will be ignored if the application is a merge or copy.

2.140

SyncSort for z/OS 1.2 Programmers Guide

REFORMAT REFORMAT Control Statement


The REFORMAT control statement defines the record layout to be produced by the join processing specified on an applications JOINKEYS control statements. Use the REFORMAT control statement to specify which fields from the SORTJNF1 and SORTJNF2 files are to be included in each record created by the join operation. The REFORMAT control statement is normally required if JOINKEYS is specified. It is optional if a JOIN control statement with the ONLY option has been specified in a join application since no records will actually be joined. In that instance, if a REFORMAT control statement is not provided and ONLY the unpaired records from one join input (SORTJNF1 DD or SORTJNF2 DD) are requested on the JOIN control statement, the records will not be reformatted and the record type and length of the join input file will be retained. If a REFORMAT control statement is not provided and ONLY the unpaired records from both join inputs are requested, the resultant records will be variable-length, regardless of the record formats of the join input data sets, and the record length will be the maximum of any fixed-length input file record length plus four (for an RDW) and any variable-length input file record length.

REFORMAT Control Statement Format


The format of the REFORMAT control statement is illustrated below: REFORMAT FIELDS= ( Fn:p 1 ,l 1 [ ,[Fn:]p 2 ,l 2 ]... [ ,[Fn:]p m ] [ ,Fn:p n ] ) [,FILL=f] Figure 68. REFORMAT Control Statement Format

FIELDS Parameter (Required)


The FIELDS parameter specifies fields to be included in the record produced by the join function. Each data field specified in the FIELDS parameter is identified by the file it originates from Fn, its position p and length l. Fn: The Fn value indicates the input file from which the data field should be copied. Code F1 for SORTJNF1 and F2 for SORTJNF2. This field is optional after the first field specification. By default, the file of the prior field specification will be used to determine the current field specification. If your join application requests only the unpaired records from one join input through the JOIN statement, then you may not reference the other join input

Chapter 2. SyncSort Control Statements

2.141

REFORMAT
file in the FIELDS parameter, since no records from that file will ever be selected. For example, if JOIN UNPAIRED,F1,ONLY is specified, then F2 may not be used in the FIELDS parameter. p The position value indicates the first byte of the field relative to the beginning of the input record. The length value indicates the length of the field.

Specifying the FIELDS Parameter for Variable-Length Records


If the REFORMAT statement only defines p,l fields, then the output of the join will be a fixed-length record. If a variable-length record format is desired when one or both input files are variable-length, then the first p,l REFORMAT field must be 1,4 (from either SORTJNFn input file) to define the RDW. This p,l specification of 1,4 must reference an Fn that is a variable-length file. The variable portion of the record must then be specified as the last REFORMAT field by coding a position p without a length l. If both files are variable-length, then the variable portion from each of the variable-length input files may be specified once at the end of the REFORMAT statement. REFORMAT FIELDS=(F1:1,4,F1:10,10,F2:25,3,F1:40,F2:50)

FILL Parameter (Optional)


The FILL parameter defines a fill byte to be used for any missing p,l field bytes. The format of the FILL parameter is illustrated below (f specifies the fill byte): FILL=f f can be specified as either a character or hexadecimal value. Specify either C'x' where x is a single EBCDIC character or X'hh' where hh represents a hexadecimal digit pair (00-FF). The need for a fill byte can arise from two conditions: A portion or an entire p,l field specification is missing due to a short variable-length record. A JOIN UNPAIRED was used and the REFORMAT FIELDS specification requires a field from the file that is not being used to generate the current joined record.

For example, an application contains the following JOIN and REFORMAT control statements: JOIN UNPAIRED,F1 REFORMAT FIELDS=(F1:10,10,F2:12,5),FILL=C'0'

2.142

SyncSort for z/OS 1.2 Programmers Guide

REFORMAT
If a record is found in SORTJNF1 that does not match a record in SORTJNF2, the unpaired record will be included in the join output and would look as follows: Position 1-10 11-15 Value Contents of the SORTJNF1 record positions 10 through 19. Filled with 0s since SORTJNF2 does not participate in building this record.

The default FILL character is a blank. Binary zeros will be used instead of the FILL character for the first four bytes of a variable-length record requiring FILL processing. This indicates that a record was not present for the REFORMAT due to JOIN UNPAIRED. For more information, see Joining Records from Multiple Files on page 3.14.

Chapter 2. SyncSort Control Statements

2.143

SORT SORT Control Statement


The SORT control statement defines the application as a sort or copy application. Either a SORT control statement or a MERGE control statement is required for every application.

Cultural Environment Support


Cultural environment support allows you to choose an alternative set of collating rules based on a specified national language. The alternative collating applies to SORT/MERGE and INCLUDE/OMIT processing. For additional detail, see LOCALE on page 5.19.

SORT Control Statement Format


The format of the SORT control statement is illustrated below.

FIELDS=(p ,l ,f ,o [,p ,l ,f ,o ]...) 1 1 1 1 2 2 2 2 SORT FIELDS=(p 1 ,l 1 ,o 1 [,p 2 ,l 2 ,o 2 ]...),FORMAT=f FIELDS=COPY o ,CENTWIN = s ,CKPT f ,CHKPT d = ( d,n (,RETRY = OFF n ,FILSZ = En [,SC = s )

,DYNALLOC

( nn,mm ) OFF

,EQUALS ,NOEQUALS

n ,SIZE = En

[,SKIPREC = n ] [,STOPAFT = n] Figure 69. SORT Control Statement Format

FIELDS Parameter (Required)


The FIELDS parameter is required. It describes the control fields.

2.144

SyncSort for z/OS 1.2 Programmers Guide

SORT
List the control fields in order of greatest to least priority, with the primary control field listed first, followed by progressively less significant fields. You can specify up to 128 control fields; however, if fields are complex, the limit for a particular execution may be less than 128. Each field specified in the FIELDS parameter is identified by its position (p), length (l), format (f) and order (o). p The position value indicates the first byte of the field relative to the beginning of the input record after INREC and/or E15 processing, if specified, have completed. Binary control fields can begin on any bit of a byte. When a binary field does not begin on a byte boundary, you must specify the bit number (0-7). For example, a position value of 21.3 refers to the 4th bit of the 21st byte of the record. l The length value indicates the length of the control field. The length value must be an integer number of bytes except for the length of a binary control field which can be specified in bits. For example, a length value of 0.5 refers to a binary control field 5 bits long. For signed fields, the length value must include the area occupied by the sign. f The format value indicates the data format. For a list of valid formats, refer to the table in the next section, Valid Formats for Sort Control Fields. If all the control fields have the same format, you can specify the format value once by using the FORMAT=f subparameter. If you specify both the individual f values and the FORMAT subparameter, the individual f values will be used for fields where they are specified. The order value indicates how the field is to be collated: A=Ascending order D=Descending order E=As modified by an E61 exit. Ascending order

Valid Formats for Sort Control Fields


The following chart lists the valid formats for sort control fields.

Chapter 2. SyncSort Control Statements

2.145

SORT

Code

Data Format

Field Length (bytes) 1 to 4091

AC*

EBCDIC characters are translated to their ASCII equivalents before sorting. Character. Records are sorted according to an alternate sequence specified either in the ALTSEQ control statement or as an installation default. Leading separate sign. An ASCII + or - precedes numeric field. One digit per byte. Trailing separate sign. An ASCII + or - trails numeric field. One digit per byte. Binary. Unsigned. Character. Unsigned. Leading overpunch sign. Hexadecimal F,C,E, or A in the first 4 bits of your field indicates a positive number. Hexadecimal D or B in the first 4 bits indicates a negative number. One digit per byte. CMP=CLC is forced. Floating sign format. An optional leading sign may be specified immediately to the left of the digits. If the sign is a -, the number is treated as negative. For other characters, the number is treated as positive. Characters to the left of the sign are ignored. Leading separate sign. An EBCDIC + or - precedes numeric field. One digit per byte. CMP=CLC is forced. Trailing separate sign. An EBCDIC + or - follows numeric field. One digit per byte. CMP=CLC is forced. Fixed point. Signed. (Equivalent to Signed Binary.) Floating point. Normalized. Signed. Packed decimal. Signed. Table 23. (Page 1 of 3) Format Code Chart

AQ*

1 to 4091

ASL*

2 to 256

AST*

2 to 256

BI CH CLO* OL*

1 bit to 4092** 1 to 4092** 1 to 256

CSF FS

1 to 16

CSL* LS* CST* TS* FI FL PD

2 to 256

2 to 256

1 to 256 2 to 16 1 to 256

2.146

SyncSort for z/OS 1.2 Programmers Guide

SORT
Field Length (bytes) 2-8

Code

Data Format

PD0*

Packed decimal. 2-8-byte packed decimal data with the first digit and trailing sign ignored. The remaining bytes are treated as packed decimal digits. Typically PD0 is used with century window processing and Y2P format; Y2P processes the year, while PD0 processes month and day. Binary. 2-digit, 1-byte binary year data treated as a 4-digit year by CENTWIN (century window) processing. Character. 2-digit character year data treated as a 4-digit year by CENTWIN (century window) processing. Processing is identical to Y2Z fields. Packed decimal. 2-digit, 1-byte packed decimal year data treated as a 4-digit year by CENTWIN (century window) processing. Packed decimal. 2-digit, 2-byte packed decimal year data. Of the four packed digits contained in the 2 bytes, the first digit and trailing sign are ignored; the two inner digits are treated as a 4-digit year by CENTWIN processing. Character or zoned decimal. 2-digit, 2-byte valid numeric data treated as a 4-digit year by CENTWIN (century window) processing, as for Y2C and Y2Z. However, certain data are not treated as year data. Data with binary zeros (X'00') or a blank (X'40') in the first byte will be collated before valid numeric year data for ascending order (after year data for descending order). Data with all binary ones (X'FF') in the first byte will be collated after valid numeric year data for ascending order (before year data for descending order). Zones are ignored, as for Y2C and Y2Z, except for data where the first byte begins with X'00', X'40' or X'FF'. Full-date, character, binary, or packed decimal formats. Full-date data formats can be used to sort or merge a variety of date fields. They can process dates ending or starting with year digits (x...xyy or yyx...x). They can also process non-date data commonly used with dates. For details, see page 2.155.

Y2B*

Y2C*

Y2D*

Y2P*

Y2S*

Y2T* Y2U* Y2V* Y2W* Y2X* Y2Y*

2-6

Table 23. (Page 2 of 3) Format Code Chart

Chapter 2. SyncSort Control Statements

2.147

SORT
Field Length (bytes) 2

Code

Data Format

Y2Z*

Zoned decimal. 2-digit, 2-byte zoned decimal year data treated as a 4-digit year by CENTWIN (century window) processing. The zones are ignored. Processing is identical to Y2C fields. Zoned decimal. Trailing overpunch in the first 4 bits of the rightmost byte gives the sign. Hexadecimal F,C,E, or A indicates a positive number. Hexadecimal D or B indicates a negative number. One digit per byte. CTO forces CMP=CLC.

ZD CTO* OT*

1 to 256

Notes: * Cannot be used with Tape Sort. ** 4084 for variable-length records. 2043 for variable-length records. Table 23. (Page 3 of 3) Format Code Chart For information on the year data formats (Y2B, Y2C, Y2D, Y2P, Y2S, and Y2Z) plus the related data format PD0 and the full-date formats, see CENTWIN Parameter (Optional) on page 2.149, Converting Year Data with Century Window Processing on INREC, OUTREC, or OUTFIL OUTREC on page 2.112, and Specifying Field-to-Field Standard Comparisons for Year Fields in the INCLUDE/OMIT Control Statement section of this chapter.

Rules for Specifying Sort Control Fields


For fixed-length records, all control fields and the sum of their lengths cannot exceed 4092 bytes. When EQUALS is in effect, the number is reduced 4 bytes to 4088 bytes. EXTCOUNT also reduces the number by 4 bytes. Thus, if both EQUALS and EXTCOUNT are in effect, the number is reduced to 4084 bytes. For variable-length records, all control fields must be located within the first 32750 bytes and the sum of their lengths cannot exceed 4084 bytes. When EQUALS is in effect, all control fields must be located within the first 32746 bytes and the sum of their lengths cannot exceed 4080 bytes. Control fields can be in contiguous or non-contiguous locations in the record. Remember that for variable-length records, the first 4 bytes are reserved for the Record Descriptor Word, so the first byte of the data portion of the record is byte 5. If the output file is a key-sequenced VSAM cluster, the VSAM key must be the first control field specified.

2.148

SyncSort for z/OS 1.2 Programmers Guide

SORT
Comparing PD and ZD Control Fields
The CMP PARM determines how PD and ZD control fields will be compared. When CMP=CPD is in effect, the Compare Decimal (CP) instruction is used for the compare. ZD fields are packed and then compared. This method has performance advantages. However, invalid PD data may cause a system 0C7 abend and program termination. Moreover, the integrity of ZD fields is only guaranteed when they contain valid ZD data. The CMP=CPD method cannot be used if any control field exceeds 16 bytes, for variable-length sorts when an even value (0, 2, 4, or 6) is specified for the VLTEST PARM, or for a Tape Sort. When CMP=CLC is in effect, no data validation is performed and the integrity of the output is maintained, even if the sign for a PD or ZD field is invalid. This method is always used for control fields that exceed 16 bytes, for variable-length sorts when an even value is specified for the VLTEST PARM, and for a Tape Sort.

CENTWIN Parameter (Optional)


The CENTWIN run-time or installation option acts on 2-digit year data. CENTWIN generates a century window (for example, 1950 through 2049) that determines the century to which a 2-digit year belongs. At run-time, CENTWIN can be specified as either a PARM option or a SORT/MERGE control statement parameter. CENTWIN ensures that year data spanning centuries will be sequenced correctly. Without CENTWIN processing, an ascending sort would sequence the year 01 before the year 98. With CENTWIN processing, the 01 field could be recognized as a twenty-first century date (2001) and would thus be sequenced after 98 (1998). For more information on specifying the CENTWIN option, see CENTWIN on page 5.7. CENTWIN SORT/MERGE processing only applies to data defined as year data formats: Y2B, Y2C, Y2D, Y2P, Y2S, Y2Z, and the full-date formats (Y2T, Y2U, Y2V, Y2W, Y2X, and Y2Y). These data formats enable SyncSort to process 2-digit year fields as 4-digit years. A related data format, PD0, can be used to process the month and day portions of packed decimal date fields. To correctly specify date fields for CENTWIN SORT processing, you should be familiar with the CENTWIN-related data formats. The following describes each of the year data formats and provides SORT control statement examples: The Y2B Format This format is used to sequence 2-digit, 1-byte binary year data with CENTWIN processing. The binary values are converted to decimal, and the two low order digits are used as year data. Thus, while binary and decimal values range from 00 to 255, year values range from 00 to 99. The relationship between binary, decimal and year values is shown in the following table:

Chapter 2. SyncSort Control Statements

2.149

SORT

Binary Value X'00' to X'63' X'64' to X'C7' X'C8' to X'FF' Table 24.

Decimal Value 00 to 99 100 to 199 200 to 255

Year Value 00-99 00-99 00-55

Possible Values Representing Year Data with Y2B

The Y2C and Y2Z Formats These formats represent 2-digit, 2-byte year data in either character (Y2C) or zoned decimal (Y2Z) format. Either Y2C and Y2Z formats can be used with data of the form X'xyxy' where y is a hexadecimal year digit 0-9 and x is hexadecimal 0 through F. Y2C and Y2Z ignore the x digits, leaving yy, the 2-digit unsigned year representation. Suppose you have a character or zoned decimal date field mmddyy that begins at byte 20. You can use either Y2C or Y2Z to process the yy field. As the following example indicates, you could specify three sort keys to correctly sort this date:

SORT FIELDS=(24,2,Y2C,A, 20,2,CH,A, 22,2,CH,A)

* Sorts yy field as 4-digit year * Sorts mm field * Sorts dd field

The yy field (24,2) will be processed according to the century window setting. For example, if CENTWIN=1945, the field yy=45 will be sequenced as if it were 1945, and yy=44 would be sequenced as if it were 2044. Thus, for an ascending sort, 44 would follow 45. The Y2D Format This format is used to sequence 2-digit, 1-byte packed decimal year data with CENTWIN processing. Use Y2D to extract the year data yy from packed decimal date fields. For example, consider a 3-byte packed decimal data field defined as X'yyddds' This field has the year yy in the first byte and the day ddd in bytes 2 and 3. The packed decimal sign s would be in the last digit (half byte) of the third byte. To sort this date field, which begins at byte 20, with 4-digit year processing, use the following SORT control statement:

2.150

SyncSort for z/OS 1.2 Programmers Guide

SORT

SORT FIELDS=(20,1,Y2D,A, 21,2,PD,A)

* Sorts 2-digit year (yy) as 4-digit year * Sorts ddds as 3 digits (ddd)

The Y2P Format This format is used to sequence 2-digit, 2-byte packed decimal year data with CENTWIN processing. Use Y2P to extract the year data yy from packed decimal date fields spanning 2 bytes. For example, a packed decimal date of the form yymmdd would be stored as 4 bytes: yymmdd = X'0yymmddC' where the trailing C (sometimes F) is a positive sign and the leading 0 pads the field on the left to make an even number of digits. Notice that the components of the date span bytes: 0y ym md dC Y2P handles this condition by ignoring the first and last half bytes of the 2-byte field specification. Thus, Y2P processes 0yym as yy, ignoring the leading digit (0) and the trailing digit m that is part of the month. The following example uses Y2P to sort the year portion of the date field, which begins at byte 20:

SORT FIELDS=(20,2,Y2P,A) * Sorts yy field as 4-digit year The field specification 20,2,Y2P treats X'0yym' as X'yy', and CENTWIN processing sorts yy as a 4-digit year yyyy. The PD0 format, described below, can assist Y2P by processing month and day data that overlap year data in the original field. The Y2S Format This format is used to sequence 2-digit, 2-byte character or zoned decimal data. The Y2S format is identical to Y2C and Y2Z for valid numeric data, but Y2S treats data that begin with X'00', X'40', or X'FF' as non-year data. Thus, the Y2S format can distinguish records that have non-year data in the first byte of the year field, allowing such records to be sorted differently from other records. Y2S treats non-year data as follows:

Chapter 2. SyncSort Control Statements

2.151

SORT
Data with binary zeros (X'00') or a blank (X'40') in the first byte will not have century window processing applied to it. Instead, such data will be collated in sequence, before valid numeric year data for ascending order or after the year data for descending order. Data with all binary ones (X'FF') in the first byte will also not have century window processing applied to it. Instead, such data will be collated after valid year numeric data for ascending order or before the year data for descending order. Zones are ignored, as for Y2C and Y2Z, except for data where the first byte begins with X'00', X'40', or X'FF'.

As an example, suppose you want to preserve the input order of header and trailer records at the start or end of the file, and your header/trailer records are identified by binary zeros (X'00'), a blank (X'40'), or binary ones (X'FF') in the first byte of the date field. The Y2S format allows CENTWIN to identify the header/trailer records and treat them differently from other records. Presuming the year data begin in column 20, you would use the following sort key specification:

SORT FIELDS=(20,2,Y2S,A)

* Sorts yy field as 4-digit year

The yy field (20,2) will be processed according to the century window setting. For CENTWIN=1945, data with header and trailer records would be sorted as follows: SORTIN Input X'F9F6' X'4001' X'F4F4' X'4000' X'0000' X'F5F1' X'FF03' Record Order after Sorting X'0000' X'4000' X'4001' X'F5F1' X'F9F6' X'F4F4' X'FF03'

Note that if the above data were sorted as Y2C or Y2Z format, the output order would be different because the records starting with X'00', X'40', and X'FF' would be interpreted as numeric years. For example, suppose the fields in the above list were defined as Y2Z and sorted with EQUALS:

SORT FIELDS=(20,2,Y2Z,A),EQUALS

2.152

SyncSort for z/OS 1.2 Programmers Guide

SORT
The data would be processed as follows: SORTIN Input X'F9F6' X'4001' X'F4F4' X'4000' X'0000' X'F5F1' X'FF03' Record Order after Sorting X'F5F1' X'F9F6' X'FF03' X'4000' X'0000' X'4001' X'F4F4'

(invalid (invalid (invalid (invalid

numeric numeric numeric numeric

data) data) data) data)

The header and trailer records are sequenced as year data according to the CENTWIN setting (CENTWIN=1945), and they lose their position at the start and end of the file. The PD0 Format This format is used to sequence 2-8 byte packed decimal data. PD0 ignores the first digit and trailing sign during processing. PD0 is normally used in conjunction with the Y2P data format. The Y2P format is used to process the 2-digit year portion of a packed decimal date field, while the PD0 format is used to process the month and day portion of the field. Although PD0 is typically used with Y2P, the PD0 format itself is not affected by CENTWIN processing. Consider the packed decimal date field used in the example above: yymmdd = X'0yymmddC' where the trailing C (sometimes F) is a positive sign and the leading 0 pads the field on the left to make an even number of digits. Notice that the components of the date span bytes: 0y ym md dC The date can be processed as follows: Y2P processes the year component X'0yym' as X'yy'. PD0 processes the month and day components X'ymmddC' as X'mmdd'.

The following SORT control statement can be used to sort the entire date with CENTWIN processing:

SORT FIELDS=(20,2,Y2P,A, * Treats X'0yym' as X'yy'; sorts yy as yyyy 21,3,PD0,A) * Treats X'ymmddC' as X'mmdd'

Chapter 2. SyncSort Control Statements

2.153

SORT
Full-Date Formats Full-date formats can be used to sort or merge various date fields, processing dates ending or starting with year digits. They also process non-date data that are used with dates. For a full description of full-date formats, see the following section.

Using Full-Date Formats with CENTWIN


SyncSorts full-date data formats enable you to sort or merge a variety of date fields. The full-date formats are Y2T, Y2U, Y2V, Y2W, Y2X, and Y2Y. These date formats can process dates ending or starting with year digits: x...xyy (for example: qyy, mmyy, dddyy, or mmddyy) yyx...x (for example: yyq, yymm, yyddd, or yymmdd)

The full-date formats also process non-date data commonly used with the dates. SyncSort interprets two-digit years (yy) according to the century window specified by the CENTWIN option. CENTWIN processing does not apply to non-date data. In most cases, for CH, ZD, and PD date fields the full-date data formats are easier to use than the 2-digit date formats. The 2-digit formats can be more difficult because you must divide the date into its components. This requires care, particularly for PD dates, where date components (q, dd, mm, or yy) may span bytes or occupy only part of a byte. The fulldate formats, on the other hand, process such dates automatically. The table below describes the full-date formats. For date forms not in the table, use the 2digit year formats or the non-year formats. Note the following symbols used in the table: y x s 0 year digit (0-9) non-year digit (0-9) sign (hexadecimal A-F) unused digit

2.154

SyncSort for z/OS 1.2 Programmers Guide

SORT

Full-Date Format Y2T

Data Format CH, BI yyx

Date Form

Example Date Form yyq yymm yyddd yymmdd yyq yyddd yymm yymmdd qyy mmyy dddyy mmddyy qyy dddyy mmyy mmddyy

Length (bytes) 3 4 5 6 2 3 3 4 3 4 5 6 2 3 3 4

yyxx yyxxx yyxxxx Y2U PD yyx (X'yyxs') yyxxx (X'yyxxxs') Y2V PD yyxx (X'0yyxxs') yyxxxx (X'0yyxxxxs') Y2W CH, BI xyy xxyy xxxyy xxxxyy Y2X PD xyy (X'xyys') xxxyy (X'xxxyys') Y2Y PD xxyy (X'0xxyys') xxxxyy (X'0xxxxyys')

Table 25. Full-Date Formats

Chapter 2. SyncSort Control Statements

2.155

SORT
The table indicates the full-date formats that can be used with character (CH), binary (BI), or packed decimal (PD) data. Note the recognized non-date values: Character or binary (Y2T and Y2W full-date formats) C'0...0' (CH zeros) C'9...9' (CH nines) Z'0...0' (ZD zeros) Z'9...9' (ZD nines) X'00...00' (BI zeros) X'40...40' (blanks) X'FF...FF' (BI ones) Packed (Y2U, Y2V, Y2X, and Y2Y full-date formats) P'0...0' (PD zeros) P'9...9' (PD nines) The following two examples illustrate how you might use the Full-Date Formats table: Suppose you have a packed decimal (PD) date field of the form mmyy. To sort this field correctly, you would use the Y2Y 3-byte format from the table. Thus, if the field starts in position 30, you would specify the following SORT control statement to sort in descending order: SORT FIELDS=(30,3,Y2Y,D) Any PD fields of all PD zeros or all PD nines will be processed automatically as nondate data. Suppose you have a character (CH) date field of the form yymmdd. To sort this field correctly, you would use the Y2T 6-byte format from the table. Thus, if the field starts in byte 40, you would specify the following SORT control statement to sort in ascending order: SORT FIELDS=(40,6,Y2T,A) Any CH zeros, CH nines, BI zeros, blanks, and BI ones will be processed automatically as non-date data. Collating Sequence with Full-Date Formats For full-date formats, the yy component is always sorted first (treated as primary key). This is so even when the yy is physically at the rightmost end of the field, as for Y2W, Y2X, and Y2Y. For example, a 6-byte Y2W field has the form xxxxyy. This is collated with the yy as the primary key and xxxx as the secondary key. Because SyncSort automatically collates the year character first, you dont have to deal with yy manually, for example by using PD0 and Y2D.

2.156

SyncSort for z/OS 1.2 Programmers Guide

SORT
It is important to understand that the xxxx component of a full-date format must be designed to collate as a unit. Suppose you have the 6-byte Y2T field yyxxxx. If you collate this field in ascending order, then yy collates first (the primary key) with xxxx collating second (secondary key). Consider two possibilities: If yyxxxx is actually yymmdd, you will be sorting first by year, then month, then day. If yyxxxx is actually yyddmm, you will sorting by year, then day, then month. In most cases, sorting in this way would not be what you intended.

To correctly collate a date, the date components must be in an order suitable for collating. For example, mmddyy and yymmdd will collate correctly, but ddmmyy or yyddmm will not. For date forms that will not collate correctly, you must use one of the 2-digit year formats (Y2B, Y2C, Y2D, Y2P, Y2S, and Y2Z). The following table shows the order for ascending collation when using full-date formats with the CENTWIN option: Full-Date Format Y2T Y2W Date Format CH, BI Ascending Sort Sequence BI zeros Blanks CH/ZD zeros Lower century dates (e.g. 1980) Higher century dates (e.g. 2010) CH/ZD nines BI ones PD zeros Lower century dates (e.g. 1980) Higher century dates (e.g. 2010) PD nines

Y2U Y2V Y2X Y2Y

PD

For a descending sort, the collation order is reversed. Other date formats (non-full-date), with the exception of Y2S, do not process non-date data; their sort sequence for ascending sorts is simply lower century dates than higher century dates.

Chapter 2. SyncSort Control Statements

2.157

SORT
Examples Using Full-Date Formats
Example 1 (Y2W) The following SORT control statement sorts a C'mmddyy' date field in ascending order, with the previously set fixed century window 1984-2083: SORT FIELDS=(10,6,Y2W,A) * Sort C'mmddyy' in ascending order * with Y2W * and previously set century window 1984-2083

The Full-Date Formats table above indicates that the 6-byte Y2W form is appropriate for a CH input field of the form xxxxyy. As shown in the following table, the output will be collated as C'yyyymmdd', with the non-date data (zeros) appearing correctly at the beginning of the sorted output. SORTIN Input mmddyy 021783 092206 081395 110210 000000 070484 043060 Example 2 (Y2T) The following SORT control statement sorts a Z'yyddd' date field in descending order, with the previously set fixed century window 1921-2020: SORT FIELDS=(20,5,Y2T,D) * Sort Z'yyddd' in descending order * with Y2T * and previously set century window 1921-2020 Record Order after Sorting mmddyy 000000 070484 081395 092206 110210 043060 021783 Actual Date after Sorting yyyy/mm/dd non-date data 1984/07/04 1995/08/13 2006/09/22 2010/11/02 2060/04/30 2083/02/17

The Full-Date Formats table above indicates that the 5-byte Y2T form is appropriate for a ZD input field of the form yyddd. As shown in the following table, the output will be collated as Z'yyyyddd', with the non-date data (nines and zeros) appearing correctly at the beginning and end of the sorted output.

2.158

SyncSort for z/OS 1.2 Programmers Guide

SORT
SORTIN Input yyddd 00000 50237 99999 20047 94001 01223 20153 21148 Example 3 (Y2Y) The following SORT control statement sorts a P'mmddyy' (X'0mmddyys') date field in ascending order, with the previously set fixed century window 1921-2020: SORT FIELDS=(26,4,Y2Y,A) * Sort P'mmddyy' in ascending order * with Y2Y * and previously set century window 1921-2020 Record Order after Sorting yyddd 99999 20153 20047 01223 94001 50237 21148 00000 Actual Date after Sorting yyyy/ddd non-date data 2020/153 2020/047 2001/223 1994/001 1950/237 1921/148 non-date data

The Full-Date Formats table above indicates that the 4-byte Y2Y form is appropriate for a PD input field of the form xxxxyy. As shown in the following table, the output will be collated as P'yyyymmdd', with the non-date data (zeros and nines) appearing correctly at the beginning of the sorted output. Note that the first two columns are in hexadecimal. SORTIN Input mmddyy 0999999C 0102250C 0032120C 0010194C 0000000C 0111501C 0080321C Record Order after Sorting mmddyy 0000000C 0080321C 0102250C 0010194C 0111501C 0032120C 0999999C Actual Date after Sorting yyyy/mm/dd non-date data 1921/08/03 1950/10/22 1994/01/01 2001/11/15 2020/03/21 non-date data

FIELDS=COPY (Required for a Copy)


Use FIELDS=COPY to copy one or more input files. Multiple files can be copied if they are concatenated to the SORTIN DD statement. Other control statements such as INREC, INCLUDE/OMIT, OUTREC, and OUTFIL may be specified in conjunction with a copy application, allowing you to edit and reformat the file(s) without sorting them. The SUM control statement and an E32 exit cannot be specified with FIELDS=COPY. All Phase 3 exits can be used.

Chapter 2. SyncSort Control Statements

2.159

SORT
CKPT/CHKPT Parameter (Optional)
The CKPT/CHKPT parameter instructs SyncSort to take a checkpoint at every end-of-volume of a SORTOUT data set when OUTFIL is not used and also at the beginning of Phase 3 before the SORTOUT data set is opened. Either spelling of this parameter is accepted. This parameter requires a SORTCKPT DD statement. It cannot be specified in conjunction with a user-issued STIMER macro or an incore sort. Checkpoints cannot be taken within a user exit routine. Refer to Chapter 13.Performance Considerations for an explanation of the Checkpoint/ Restart feature.

DYNALLOC Parameter (Optional)


The format of the DYNALLOC parameter is illustrated below.

,DYNALLOC

d = ( d,n OFF

RETRY = ( nn,mm ) OFF

[,SC = s )

Figure 70. DYNALLOC Parameter Format DYNALLOC requests the dynamic allocation of SORTWK data sets on device type d. Specify the device type either as a decimal number (e.g., 3390) or by the system generic name (e.g., SYSDA). Any disk device accepted for a SORTWK DD statement can be specified. Note that if VIO is specified it will be ignored, and the installation default for the DYNALLOC device type will be used in its place. Note that the DYNALLOC parameter may be used alone, without any subparameters. In this case, the DYNALLOC installation default settings are used. For MAXSORT applications, n is the number of SORTWK data sets that will be allocated. As many as 32 SORTWK data sets can be specified. The default for n is 3. For non-MAXSORT applications, n can be 1 through 255. This value specifies the number of SORTWK data sets that can potentially be allocated. For values of n that are 31 or less, SyncSort can automatically raise the number to 32 if the application requires it. When n is 33 through 255, this value specifies the maximum number of SORTWK data sets that can be allocated. DYNALLOC=OFF can be specified to override a DYNALLOC=ON installation default.

2.160

SyncSort for z/OS 1.2 Programmers Guide

SORT
Normally for both MAXSORT and non-MAXSORT applications, any SORTWK data sets provided in the JCL will contribute towards the value of n. For instance, if n was set to 40 in a non-MAXSORT application and 30 SORTWKs were provided in the JCL, DYNALLOC could obtain 10 additional SORTWKs if needed. Note that there is an installation option to disable DYNALLOC if SORTWKxx DD statements are present. SyncSort uses the value specified in the RETRY parameter to request automatic DYNALLOC retry. This facility attempts to avoid a sortwork capacity exceeded condition when disk space is not immediately available to satisfy a DYNALLOC request. SyncSort will automatically retry a specified number of times and wait a prescribed interval between DYNALLOC requests. The nn in the first position designates the number of times SyncSort will retry a failed DYNALLOC request. The minimum allowed is 0 and the maximum is 16. The mm in the second position designates the number of minutes SyncSort waits between each DYNALLOC request. The minimum allowed is 0 and the maximum is 15. A value of 0 can be used to request an immediate retry. RETRY=OFF or an nn of 0 can be specified to override a RETRY=ON installation default. In an environment where DFSMS manages temporary work data sets, the SC subparameter specifies a storage class s for SyncSort to use when dynamically allocating SORTWORK data sets. The storage administrator at your installation defines the names of the storage classes you can specify. Note that an installation written automatic class selection (ACS) routine can override the storage class you specify. If SMS is not installed or active to manage temporary work data sets, the d device specification will be used in the SORTWORK dynalloc request.

EQUALS/NOEQUALS Parameter (Optional)


The EQUALS parameter insures that the original order of equal-keyed records is preserved. These records will be in the same order in the output file as they were in the input file. NOEQUALS, the default, specifies that equal-keyed records may not be written in their original input order. When the EQUALS parameter is used with the SUM control statement, the first of the equal-keyed records is retained with the sum; all other records are deleted after the specified field(s) have been summed. EQUALS/NOEQUALS can also be specified as a PARM option on the EXEC statement. If this option is specified both on the SORT control statement and as a PARM option, the SORT specification takes precedence. Performance is usually improved when NOEQUALS is in effect.

Chapter 2. SyncSort Control Statements

2.161

SORT
FILSZ Parameter (Optional)
The FILSZ parameter specifies the actual (FILSZ=n) or estimated (FILSZ=En) decimal number of records to be sorted. This number should reflect any changes produced by INCLUDE/OMIT, E14 and/or E15, SKIPREC and STOPAFT processing. If FILSZ=n is specified, SyncSort will terminate unless exactly n records are processed. If FILSZ is specified for a Tape Sort, use only the En specification. This value should indicate the number of records in the input file without taking into account records added or deleted by an E14 or E15 exit. FILSZ can also be specified as a PARM option on the EXEC statement. If this option is specified both on the SORT control statement and as a PARM option, the PARM specification takes precedence.

SIZE Parameter (Optional)


The SIZE parameter specifies the actual (SIZE=n) or estimated (SIZE=En) decimal number of records read from the input file. Unlike the FILSZ parameter, this number should not reflect any changes produced by INCLUDE/OMIT or exit processing, but should reflect SKIPREC and STOPAFT processing. If the FILSZ parameter is not specified and SIZE=n is specified, SyncSort will terminate unless exactly n records are processed. If the FILSZ parameter is specified, the SIZE value is considered an estimate whether or not it is preceded by an E.

SKIPREC Parameter (Optional)


The SKIPREC=n parameter instructs SyncSort to skip a decimal number of records before the input file is sorted or copied. The n records skipped are deleted from the input file before E15 and INCLUDE/OMIT processing, if specified, take place. If SKIPREC is specified as a PARM option as well as on the SORT control statement, the PARM specification takes precedence.

STOPAFT Parameter (Optional)


The STOPAFT=n parameter specifies the number of records to be sorted or copied. These will be the first n records after E15, INCLUDE/OMIT and SKIPREC processing, if specified, have completed. If STOPAFT is specified as a PARM option as well as on the SORT control statement, the PARM specification takes precedence. STOPAFT cannot be specified for a Tape Sort.

2.162

SyncSort for z/OS 1.2 Programmers Guide

SORT
Sample SORT Control Statements
SORT FIELDS=(2.3,2,BI,D,8,2.4,BI,A,25,10,CH,A,15,10,LS,D) Figure 71. Sample SORT Control Statement This sample SORT control statement indicates four control fields: The first, or primary, field begins in bit 4 of byte 2, is 2 bytes long, is in binary format and is to be sorted in descending order. The second control field begins in byte 8, is 2 bytes 4 bits long, is a binary format and is to be sorted in ascending order. The third control field begins on byte 25, is 10 bytes long, is in character format and is to be sorted in ascending order. The fourth control field begins on byte 15, is 10 bytes long, is an EBCDIC numeric field with a leading separate sign and is to be sorted in descending order.

SORT FIELDS=(20,5,A,5,10,D,30,5,A),FORMAT=CH,CKPT Figure 72. Sample SORT Control Statement This sample SORT control statement specifies the following: There are three control fields. Because all three fields have the same data format (in this case, character), the FORMAT=CH subparameter is specified so that the CH value does not have to be specified for each of the fields. The first control field begins on byte 20, is 5 bytes long and is to be sorted in ascending order. The second control field begins on byte 5, is 10 bytes long and is to be sorted in descending order. The third control field begins on byte 30, is 5 bytes long and is to be sorted in ascending order. SyncSort will take a checkpoint.

Chapter 2. SyncSort Control Statements

2.163

SUM SUM Control Statement


The SUM control statement deletes records with equal control fields and optionally summarizes specified numeric fields on those records. Equal keyed records are processed pair by pair. If numeric fields are to be summarized, the data in the summary fields are added, the sum is placed in one of the records, and the other record is deleted. Provided arithmetic overflow does not occur, the SUM control statement produces only one record per sort key in the output data set. The records deleted by sum can optionally be written to a separate data set. The SUM control statement cannot be used when FIELDS=COPY is specified on the SORT or MERGE control statement or for a Tape Sort.

SUM Control Statement Format


The format of the SUM control statement is illustrated below.

FIELDS=(p 1 ,l 1 ,f 1 [,p 2 ,l 2 ,f 2 ] ...) SUM FIELDS=(p 1 ,l 1 [,p 2 ,l 2 ] ...),FORMAT=f [,XSUM] FIELDS=NONE Figure 73. SUM Control Statement Format

FIELDS Parameter (Required)


The FIELDS parameter defines the numeric fields to be summed when the control fields of two or more records are equal. Specify FIELDS=NONE to reduce the sorted data to one record per sort key without summarizing any numeric fields. Each field specified in the FIELDS parameter is identified by its position p, length l and format f. p The position value indicates the first byte of the field relative to the beginning of the input record after INREC and/or E15 processing, if specified, have completed. The field must begin on a byte boundary. The length value indicates the length of the field. The length must be an integer number of bytes. Refer to the chart below for the permissible lengths. The format value indicates the data format. Fields with BI, FI, FL, PD and ZD formats can be summarized. If all the summary fields have the same format, you can specify the format value once by using the FORMAT=f subparameter. If both the individual f values and the FORMAT subparameter

2.164

SyncSort for z/OS 1.2 Programmers Guide

SUM
are specified, the individual f values will be used for fields where they are specified.

FORMAT CODE BI FI FL PD ZD 2, 4, or 8 bytes 2, 4, or 8 bytes 4, 8, or 16 bytes 1 to 16 bytes 1 to 18 bytes Table 26.

PERMISSIBLE LENGTH

Permissible Lengths for SUM Fields

XSUM Parameter (Optional)


Specify the XSUM parameter if you want records deleted by SUM processing to be written to a data set defined by the SORTXSUM DD statement. These records will be written to SORTXSUM at the time of SUM processing. The records will not undergo OUTREC, E35, and OUTFIL processing because such processing occurs after SUM processing. The DCB BLKSIZE of the SORTIN data set will not be used to determine the BLKSIZE of the SORTXSUM data set. System determined blocksize will be used when enabled and appropriate. Unblocked output will be generated if system determined blocksize has been disabled and an explicitly specified blocksize has not been provided in the JCL. The XSUM file will be sequenced in the same order as the SORTOUT file. Note that XSUM may increase system requirements: Adding XSUM to an existing sort application may result in an increase in the amount of SORTWORK space required. This occurs because XSUM delays all summing until Phase 3. Adding XSUM to an existing MAXSORT application could cause the generation of additional intermediate output files (SORTOU00 or SORTOUnn). This occurs because XSUM delays SUM processing until the final MAXSORT merge pass. XSUM may require additional main memory. Specify a region size of 512K or more.

Chapter 2. SyncSort Control Statements

2.165

SUM
General Considerations for SUM
If NOEQUALS is in effect, the record which is retained is determined arbitrarily. If EQUALS is in effect, the record which is retained is the first record read. In a SORT application, in a MERGE, the retained record will be from the lowest-numbered input file. The EQUALS parameter can be specified on the SORT or MERGE control statement or as a PARM option. A sort or merge control field cannot be summarized. A portion of a control field cannot be included in a sum field. Sum fields may not overlap each other. Non-sum fields remain unchanged and are retained from the record which contains the sum. If arithmetic overflow or underflow occurs during the summing of two records, those records are not summarized and neither record is deleted. Further processing is determined by the option selected at installation through the SUMOVFL parameter or the run time parameter OVFLO. If the RC16 option of this parameter has been selected, processing will terminate with a WER049A critical error. For the RC0 (the delivered default) or the RC4 option, sum processing will continue and a WER049I message will be issued (only for the first occurrence). If a subsequent pair of records with equal control fields can be summarized without causing overflow or underflow, they will be summarized. To avoid arithmetic overflow, use the INREC control statement to insert zeros of the proper format immediately before the sum field. For example, for a PD field, use nZ to insert binary zeros. Remember that the first 4 bytes of variable-length records are reserved for the Record Descriptor Word, so the first byte of the data portion of the record is byte 5. SUM is incompatible with an incore sort. If you specify the SUM control statement, allocate SORTWKxx data sets in the JCL or use the DYNALLOC feature for dynamic SORTWK allocation. If no JCL SORTWKs are provided and DYNALLOC is disabled by default, SUM will cause DYNALLOC to be enabled. When FL fields are summarized, user-issued SPIE macros are not permitted and exit routines must not produce exponent overflow or underflow. Because of the numeric rounding performed by the hardware, the exact sum depends on the order in which fields are summed. Thus, the sum may vary slightly for different executions. By default, the sign byte of a positive summarized ZD field will be converted to printable format. If you want to disable this action, use the NZDPRINT PARM option. Refer to ZDPRINT on page 5.33.

2.166

SyncSort for z/OS 1.2 Programmers Guide

SUM
Sample SUM Control Statements
The following SUM control statement eliminates equal-keyed records without summarizing numeric fields. The XSUM option causes the eliminated records to be written to a data set defined on the SORTXSUM DD statement.

SUM FIELDS=NONE,XSUM Figure 74. Sample SUM Control Statement Records with equal control fields will be eliminated from SORTOUT or SORTOFnn data sets so that only one record is retained. The following SUM control statement summarizes two numeric fields on records with equal control fields.

SUM FIELDS=(20,4,32,4),FORMAT=PD Figure 75. Sample SUM Control Statement When the control fields are equal, this SUM control statement summarizes the numeric data in the fields beginning in bytes 20 and 32. Because both fields are in packed decimal format, the FORMAT=PD subparameter is used so that the PD value does not have to be specified for each field. Comprehensive examples illustrating the SUM control statement are provided in Chapter 3.How to Use SyncSorts Data Utility Features.

Chapter 2. SyncSort Control Statements

2.167

SUM

2.168

SyncSort for z/OS 1.2 Programmers Guide

Chapter 3. How to Use SyncSorts Data Utility Features

Introduction
This chapter assumes that you already know how to sort records and are ready to use SyncSorts Data Utility features for any or all of the following: Selecting only those input records and data fields that are needed for an application. Eliminating duplicate records. Consolidating records into a single record that contains the sum of any numeric data fields. Joining records. Making output data printable and easy to read. Writing a multi-sectioned report complete with headers and trailers. Generating several output files and reports with a single pass of the sort.

The following examples show how you can accomplish these tasks with SyncSort. Each example is self-contained and provides coding instructions for both the required JCL and the necessary control statements. Use them as starting points for your own applications. For details of control statement syntax see Chapter 2. SyncSort Control Statements.

Chapter 3. How to Use SyncSorts Data Utility Features

3.1

Sample Data Utility Applications


The following chart lists applications that demonstrate SyncSorts features. Feature Selecting Input Records Selecting Relevant Fields from the Input Records Combining Records within a File Joining Records from Multiple Files Making Output Records Printable and Easy to Read Application Including Relevant Records Omitting Irrelevant Records Selecting a Number of Fields from Longer Records Eliminating Irrelevant Data Field(s) Selecting Fields from Variable-Length Records Combining Records and Summing Numeric Data Fields Eliminating Duplicate Records Joining Records Reordering the Positions of Record Fields Inserting Blanks and Repositioning Record Fields Inserting Binary Zeros Converting Unprintable Data to Readable Form Converting Unprintable Data to Hexadecimal Format Converting and Editing Unprintable Data Putting a Data Field in Standard Format Converting from Variable to Fixed-Length Format Printing Input Records on Multiple Output Lines Dividing Output into Sections Writing a Title Page for a Report Writing a Page Header Writing a Section Header Using a Header to Eliminate Duplication Information within a Section Writing a Report Trailer or Summary Writing a Page Trailer Totaling Data at the End of a Report Subtotaling Data at the End of a Page Totaling Data at the End of a Section Printing Maximum, Minimum and Average Data in Section Trailers Obtaining a Count of Data Records Obtaining a Cumulative (Running) Count of Data Records Generating Several Output Files with Different Information Writing Identical Output Files to Different Devices Page 3.3 3.5 3.7 3.8 3.9 3.11 3.12 3.14 3.24 3.26 3.28 3.29 3.31 3.32 3.34 3.36 3.37 3.39 3.41 3.43 3.44 3.46 3.48 3.49 3.50 3.52 3.53 3.56 3.58 3.59 3.62 3.64

Dividing a Report into Sections Writing Headers and Trailers for a Report

Totaling and Subtotaling Data

Obtaining Maximum, Minimum and Average Data Counting Data Records

Creating Multiple Output Files

Selecting Input Records


When only certain records from an input file are needed for an application, SyncSort allows you to set up one or more logical conditions for including only those records. Alternately,

3.2

SyncSort for z/OS 1.2 Programmers Guide

you may specify conditions for omitting records from an application. Each condition is based on a comparison between two record fields or between a record field and a constant. You may specify the constant as a positive or negative decimal, a hexadecimal or binary constant, or a character literal. Multiple conditions may be specified, provided you connect them with ANDs and ORs. To specify the conditions for selecting records, use the INCLUDE/OMIT control statement. For complete syntax, and examples of bit level criteria in record selection, see INCLUDE/ OMIT Control Statement on page 2.19 When processing variable-length records, by default all fields specified must be contained within the record. If an application is expected to reference fields not completely contained within the record, see VLTESTI on page 5.32. VLTESTI provides for processing of records that do not contain all fields.

Including Relevant Records


Example: A school board requires a list of all students performing below their grade level on standardized exams. (The record layout is given in Figure 76 and a sample record is given in Figure 77.)

Figure 76. Input Record Layout

Chapter 3. How to Use SyncSorts Data Utility Features

3.3

Figure 77. Sample Student Record To generate the list, the following is coded:

//SUBLEV JOB // EXEC PGM=SYNCSORT //SYSOUT DD SYSOUT=* //* //SORTIN DD DSN=WWBRSM.STUDENTS,DISP=SHR //SORTOUT DD SYSOUT=* //SORTWK01 DD UNIT=SYSDA, // SPACE=(CYL,15) //SYSIN DD * INCLUDE COND=(29,2,LT,25,2,OR,27,2,LT,25,2), FORMAT=PD SORT FIELDS=(1,14,CH,A)

Gives the Jobname Identifies the Program Assigns SyncSort Messages to I/O Device Defines Input Data Set Defines Output Data Set Defines Intermediate Storage

Selects Records Sorts Records

Figure 78. JCL and Required Control Statements Explanation: In this application, two comparisons are necessary to identify the records needed for the list: the Grade field (25,2) has to be compared to the students Reading Score field (27,2) and to the Mathematics Score field (29,2). All numeric fields on the student records are in packed-decimal (PD) format. The two-clause INCLUDE statement (see Figure 78) guarantees the selection of the needed records from the file. The first clause (29,2,LT,25,2) guarantees that records with Math Scores less than the Grade field are INCLUDED. The second clause (27,2,LT,25,2) guarantees that records with Reading Scores less than the Grade field are also INCLUDED. The OR connecting the two clauses guarantees that if either or both of the scores are less than the Grade field, the record is selected. Finally, since all the fields are in packed-decimal format (PD), FORMAT=PD is specified.

3.4

SyncSort for z/OS 1.2 Programmers Guide

The sample record shown above will be INCLUDED because the students Math Score (047F) is lower than the Grade level (050F).

Omitting Irrelevant Records


Example: Records that have an Invoice Status Code of F (fully paid) are to be omitted in preparing a list of only those customers with outstanding payments. (The input record layout is given in Figure 79 and a sample input record is given in Figure 80.)

Figure 79. Input Record Layout

Figure 80. Sample Input Record To produce this list of customers selected from the masterfile, the following is coded.

Chapter 3. How to Use SyncSorts Data Utility Features

3.5

//OUTPAY JOB // EXEC PGM=SYNCSORT //SYSOUT DD SYSOUT=* //* //SORTIN DD DSN=NEWINV,DISP=SHR //SORTOUT DD SYSOUT=* //SORTWK01 DD UNIT=SYSDA,SPACE=(CYL,20) //SYSIN DD * OMIT COND=(80,1,CH,EQ,C'F') SORT FIELDS=(1,29,CH,A)

Gives the Jobname Identifies the Program Assigns SyncSort Messages to I/O Device Defines Input Data Set Defines Output Data Set Defines Intermediate Storage Omits Records Sorts Records

Figure 81. JCL and Required Control Statements Explanation: In this application, a simple comparison is necessary to identify those masterfile records that are not needed: the Invoice Status Code field (80,1,CH) has to be compared to the constant 'F'. The OMIT statements condition, 80,1,CH,EQ,C'F', (see Figure 81) guarantees that invoice records, like the sample record shown above, with the Invoice Status Code 'F' are omitted from the sort.

Selecting Relevant Fields from the Input Records


Input records often contain some information that is not relevant to a specific application. For example, records in a personnel masterfile might, in addition to addresses, include salaries and other confidential information that is not required for preparing a mailing list. SyncSorts Data Utility features allow you to select only those record fields that contain necessary data and to eliminate those that do not. More important, SyncSort enables you to do this editing before the records are sorted. As a result, the sort has fewer bytes to handle and processing is more efficient. For complete syntax of the INREC control statement, see INREC Control Statement on page 2.38.

INREC FIELDS=(p1,l1[,p2,l2,...,pn,ln]) Figure 82. Basic INREC Statement Format p,l Specify the beginning position and length in bytes of the input records relevant fields. When specifying contiguous fields, or fields that directly follow one another, you can simply indicate the starting position of the first field together with the combined length of the fields that are contiguous.

3.6

SyncSort for z/OS 1.2 Programmers Guide

Selecting a Number of Fields from Longer Records


Example: A school wants to rank the entire student body by grade point index. This application simply requires selecting the two relevant fields out of all the fields in the student records and, then, sorting on the Grade Point Index field. (The Input Record layout is given in Figure 83.)

Figure 83. Input Record Layout To include only the relevant fields and generate the ranked list of students, the following is coded:

//RANK // //SYSOUT //* //SORTIN //SORTOUT //SORTWK01 //SYSIN INREC SORT

JOB EXEC DD

PGM=SYNCSORT SYSOUT=*

DD DSN=TOT.STUDENTS,DISP=SHR DD SYSOUT=* DD SPACE=(CYL,10),UNIT=SYSDA DD * FIELDS=(1,9, 74,2) FIELDS=(10,2,PD,D)

Gives the Jobname Identifies the Program Assigns SyncSort Messages to I/O Device Defines Input Data Set Defines Output Data Set Defines Intermediate Storage Selects Record Fields Sorts Records

Figure 84. JCL and Required Control Statements Figure 85 shows the input record after INREC processing.

Chapter 3. How to Use SyncSorts Data Utility Features

3.7

Figure 85. Form of Post-INREC Record Explanation: Specifying the two relevant data fields--the Social Security Number (1,9) and the Grade Point Index (74,2)--on the INREC statement provides the sort with necessary data for the application and eliminates the fields that are not relevant to the application. INREC processing thus shortens each record to just a little under 14% of its original size.

Eliminating Irrelevant Data Field(s)


Example: For an inventory list, the price code on the masterfile records is not necessary. (The masterfile record layout is given in Figure 86.)

Figure 86. INPUT Record Layout To eliminate the Price Code field and generate the inventory list, the following is coded.

3.8

SyncSort for z/OS 1.2 Programmers Guide

//INVENTR // //SYSOUT //* //SORTIN //SORTOUT //SORTWK01 //SYSIN INREC SORT

JOB EXEC DD

PGM=SYNCSORT SYSOUT=*

DD DSN=INV.WARHOUS,DISP=SHR DD SYSOUT=* DD SPACE=(CYL,15),UNIT=SYSDA DD * FIELDS=(1,17, 19,3) FIELDS=(1,5,CH,A) . . .

Gives the Jobname Identifies the Program Assigns SyncSort Messages to I/O Device Defines Input Data Set Defines Output Data Set Defines Intermediate Storage Selects Record Fields Sorts Records

Figure 87. JCL and Required Control Statements Figure 88 shows the input record after INREC processing.

Figure 88. Post-INREC Record Layout Explanation: Specifying only those fields that are necessary eliminates those that are not necessary for the application. The Price Code field (18,1) has not been specified on the INREC statement; it will be deleted from the input records before the records are sorted by item number for the list.

Selecting Fields from Variable-Length Records


Example: For each volume in its collection, a library requires the catalog number and any information concerning translations, other volumes in a series, additional copies on file, and so on. The catalog file consists of variable-length records, and except for the catalog

Chapter 3. How to Use SyncSorts Data Utility Features

3.9

number, the required information is contained in the variable-length portion of each record. (The record layout is given in Figure 89.)

Figure 89. Sample Record Layout To include only the relevant fields on the input records and to generate this list, the following is coded.

//LISTCAT // //SYSOUT //* //SORTIN //SORTOUT //SORTWK01 //SYSIN INREC SORT

JOB EXEC DD

PGM=SYNCSORT SYSOUT=*

DD DSN=LIB.CATALOG,DISP=SHR DD SYSOUT=* DD SPACE=(CYL,10),UNIT=SYSDA DD * FIELDS=(1,14, 98) FIELDS=(5,10,ZD,A) . . .

Gives the Jobname Identifies the Program Assigns SyncSort Messages to I/O Device Defines Input Data Set Defines Output Data Set Defines Intermediate Storage Selects Record Fields Sorts Records

Figure 90. JCL and Required Control Statements Figure 91 shows the input record after INREC processing.

3.10

SyncSort for z/OS 1.2 Programmers Guide

Figure 91. Form of Post-INREC Record Explanation: When selecting fields on variable-length records, you must observe these two restrictions: (1) The position of the RDW cannot be affected; and (2) at least one byte from the fixed-length portion of the record, in addition to the RDW, must be specified. On the above INREC statement, the first 14 bytes of each record the 4-byte RDW and the fixedlength Catalog Number field are retained unchanged. The next field which contains more information, as required is indicated only by position (98) since it is of variablelength. This causes the entire variable-length portion of the record (beginning with byte 98) to be included after the initial 14 bytes of the post-INREC record. SyncSort automatically adjusts the RDW to reflect the new record length.

Combining Records within a File


Sometimes you may want to shorten a file by consolidating records that have some information in common. For example, a companys invoice file may contain more than one record for any customer to whom multiple invoices have been issued. In some applications it might then be feasible to consolidate such records that is, to combine records with identical Customer Name and Address fields into a single record containing the sum of that customers charges and payments. The SUM control statement allows you to combine records in this way. For SUM control statement syntax, see SUM Control Statement on page 2.164.

Combining Records and Summing Numeric Data Fields


Example: For an inventory list, a company requires a single record for each product, indicating its item number, warehouse code, and the total quantity in stock. (Figure 92 gives the sample record layout.)

Chapter 3. How to Use SyncSorts Data Utility Features

3.11

Figure 92. Input Record Layout To combine those inventory records with identical item numbers and warehouse codes and to produce the required list, the following is coded.

//INVENT JOB // EXEC PGM=SYNCSORT //SYSOUT DD SYSOUT=* //* //SORTIN DD DSN=WRHSE.INVENT,DISP=SHR //SORTOUT DD SYSOUT=* //SORTWK01 DD SPACE=(CYL,6),UNIT=SYSDA //SYSIN DD * SORT FIELDS=(6,1,CH,A,1,5,ZD,A) SUM FIELDS=(7,12,PD)

Gives the Jobname Identifies the Program Assigns SyncSort Messages to I/O Device Defines Input Data Set Defines Output Data Set Defines Intermediate Storage Sorts Records Combines Records and Sums Numeric Data

Figure 93. JCL and Required Control Statements Explanation: The list is generated by sorting on the Warehouse Code field (6,1,CH) and the Item Number field (1,5,ZD). Records that have identical information in both these fields are combined into a single record that contains the sum or total of those records Quantity fields (7,12,PD). That is, the single record will show how many items with the same number are in each warehouse.

Eliminating Duplicate Records


Example: A mailing list is being prepared from an invoice file. To eliminate duplicate entries, any multiple invoice records for the same customer are combined into a single record. (Figure 94 gives the sample record layout.)

3.12

SyncSort for z/OS 1.2 Programmers Guide

Figure 94. Input Record Layout To combine multiple invoice records and generate the mailing list, the following is coded.

//MAILLIST JOB // EXEC PGM=SYNCSORT //SYSOUT DD SYSOUT=* //* //SORTIN DD DSN=INV.MAST,DISP=SHR //SORTOUT DD SYSOUT=* //SORTWK01 DD SPACE=(CYL,5),UNIT=SYSDA //SYSIN DD * INREC FIELDS=(17,28) SORT FIELDS=(1,23,CH,A) SUM FIELDS=NONE

Gives the Jobname Identifies the Program Assigns SyncSort Messages to I/O Device Defines Input Data Set Defines Output Data Set Defines Intermediate Storage Selects Relevant Fields Sorts Records. Reference is to Post-INREC Record Eliminates Duplicate Records

Figure 95. JCL and Required Control Statements Explanation: To prepare the customer mailing list, the only information required from the invoice records is located in the Company Name field (17,23) and the Address field (40,5), which are selected by the INREC statement. Sorting these records in ascending order by company name generates an alphabetical list. Then, because the file contains a record for every transaction, the SUM statement is used to avoid duplicate listings of customers who have had more than one transaction. Note that because none of the fields contains numeric data to be summed, the FIELDS=NONE parameter is used.

Chapter 3. How to Use SyncSorts Data Utility Features

3.13

Joining Records from Multiple Files


Sometimes you may want to join two or more files to combine their information for reports or other purposes. For example, a bank may want to create a report based on information in three separate files. In some applications it might then be feasible to join these files that is, to join the first two files into one, and then combine that one with a third file for final reporting.

Joining Records
Example: A bank wants to join three separate files to produce a report that shows recent transactions by customers, sorted by outstanding balance. The final report shows transaction information from a transaction file, customer name and address data from a master file containing basic customer information, and the outstanding balance from a third file containing such information. The record layout for the transaction file is contained below in Figure 96.

TR
1

SA N

N IO T C

M U

R BE N IO T C A

O M

N U

T N ER IO MB T C U A N S N R A ME TR TO S U C
26 27

TR

SA N

A D

TE

78

15 16

CH

CH

CH

ZD

31

Figure 96. Input Record Layout for First File

3.14

SyncSort for z/OS 1.2 Programmers Guide

The master file record layout is shown below in Figure 97.

A M

M TO S U R C BE R M TE N U S

ER ER A N

E M M TO ER

D A

S ES

U C

M O ST

C
20 21

S U

1 ZD

67 CH

CH

22 Figure 97. Input Record Layout for Second File

These two files can be joined on the transaction customer number from the first file and the master customer number from the second file. These numbers are in zoned decimal (ZD) format, but because all of the zones are the same in every record, these fields can be used as character data for the join function. Figure 98 contains the JCL and control statements to join these two files.

Chapter 3. How to Use SyncSorts Data Utility Features

3.15

//* //* FIRST STEP //* JOIN TRANSACTION FILE WITH MASTER FILE CUSTOMER INFO INTO //* INTERMEDIATE FILE. //* ADDITIONALLY AN OUTFIL DATA SET WILL BE PRODUCED TO DISPLAY //* THE JOINED RECORDS CREATED IN THE INTERMEDIATE FILE. //SORT1 EXEC PGM=SYNCSORT //* TRANSACTION FILE //*TRAN# TRANAMT DATE TCUSTNO //SORTJNF1 DD * 000001 0310.00 12/01/2002 2178I 000002 8055.22 12/02/2002 2123D 000003 0310.00 12/05/2002 2178I 000004 0020.00 12/06/2002 2111A //* //* MASTER RECORD FILE //*MCUSTNO CUSTNAME CUSTADDRESS //SORTJNF2 DD * 7654C JOSEPH SMITH NY 2111A JAMES JONES NJ 2178I JOHN JACKSON DE 2123D MARY LEE FL //SORTOUT DD DSN=&&TEMP,DISP=(,PASS),UNIT=SYSDA //SORTOF01 DD SYSOUT=* //SYSOUT DD SYSOUT=* //SYSIN DD * * * JOINKEYS FILE=F1,FIELDS=(TCUSTNO) * JOINKEYS FILE=F2,FIELDS=(MCUSTNO) * REFORMAT FIELDS=(F1:DATE,TRAN#,TRANAMT,TCUSTNO,F2:CUSTNAME, * CUSTADDRESS) * JOINKEYS FILE=F1,FIELDS=(27,5,A) JOINKEYS FILE=F2,FIELDS=(1,5,A) REFORMAT FIELDS=(F1:16,11,1,7,8,8,27,6,F2:7,14,21,3) SORT FIELDS=COPY OUTFIL FILES=01,HEADER2=('DATE ','TRAN# ','TRANAMT ', 'CUST# ','CUSTOMER NAME ','ADD') //*

Figure 98. JCL and Required Control Statements Next, a third file containing outstanding balances is added.

3.16

SyncSort for z/OS 1.2 Programmers Guide

A M

M TO S U R C BE ER UM ST N O

ER IN G BA

LA

E C

TA TS U

1 ZD

67 CH

15 Figure 99. Input Record Layout for Third File

Chapter 3. How to Use SyncSorts Data Utility Features

3.17

To do that, the following is coded.


//********************************************************** //*SECOND STEP: //*JOIN INTERMEDIATE OUTPUT WITH OUTSTANDING BALANCE FILE FOR FINAL //* REPORT. //* THE REPORT WILL PRESENT THE DATA WITH HEADINGS INDICATING //* THE FIELDS PROVIDED. //* //SORT2 EXEC PGM=SYNCSORT //* INTERMEDIATE OUTPUT FILE (FIELDS IN DIFFERENT LOCATION, SO NEED //* RENAMING) //*DATE_TEMP,TRAN#_TEMP,TRANAMT_TEMP,TCUSTNO_TEMP,CUSTNAME_TEMP, //*CUSTADDRESS_TEMP //SORTJNF1 DD DSN=&&TEMP,DISP=(OLD,DELETE) //* //* OUTSTANDING BALANCE FILE //*MCUSTNO OUTSTANDINGBALANCE //SORTJNF2 DD * 7654C 00000.00 2111A 09876.54 2178I 00100.00 2123D 13555.22 //SORTOUT DD SYSOUT=* //SYSOUT DD SYSOUT=* //SYSIN DD * * *JOINKEYS FILE=F1,FIELDS=(TCUSTNO_TEMP) *JOINKEYS FILE=F2,FIELDS=(MCUSTNO) *REFORMAT FIELDS=(F1:DATE_TEMP,TRAN#_TEMP,TRANAMT_TEMP,TCUSTNO_TEMP, * CUSTNAME_TEMP,CUSTADDRESS_TEMP,F2:OUTSTANDINGBALANCE) *SORT FIELDS=(OUTSTANDINGBALANCE_RELOCATED) *OUTREC FIELDS=(DATE_TEMP_RELOCATED,3X,OUTSTANDINGBALANCE_RELOCATED,3X, * TRAN#_TEMP_RELOCATED,3X,TRANAMT_TEMP_RELOCATED,3X, * TCUSTNO_TEMP_RELOCATED,3X,CUSTNAME_TEMP_RELOCATED,3X, * CUSTADDRESS_TEMP_RELOCATED) * JOINKEYS FILE=F1,FIELDS=(27,5,A) JOINKEYS FILE=F2,FIELDS=(1,5,A) REFORMAT FIELDS=(F1:1,49,F2:7,8) SORT FIELDS=(50,8,CH,A) OUTREC FIELDS=(1,11,3X,50,8,3X,12,7,3X,19,8,3X,27,6,3X,33,14,3X,47,3) OUTFIL FILES=OUT,HEADER2=('DATE ',3X,'OUTSTBAL',3X, 'TRAN# ',3X,'TRANAMT ',3X, 'CUST# ',3X,'CUSTOMER NAME ',3X,'ADD')

Figure 100. JCL and Required Control Statements

3.18

SyncSort for z/OS 1.2 Programmers Guide

The output from the first step:


DATE 12/06/2002 12/02/2002 12/05/2002 12/01/2002 TRAN# 000004 000002 000003 000001 TRANAMT 0020.00 8055.22 0310.00 0310.00 CUST# 2111A 2123D 2178I 2178I CUSTOMER NAME JAMES JONES MARY LEE JOHN JACKSON JOHN JACKSON ADD NJ FL DE DE

Figure 101. Sample Output The output from the second step:
DATE 12/05/2002 12/01/2002 12/06/2002 12/02/2002 OUTSTBAL 00100.00 00100.00 09876.54 13555.22 TRAN# 000003 000001 000004 000002 TRANAMT 0310.00 0310.00 0020.00 8055.22 CUST# 2178I 2178I 2111A 2123D CUSTOMER NAME JOHN JACKSON JOHN JACKSON JAMES JONES MARY LEE ADD DE DE NJ FL

Figure 102. Sample Output

Retaining Unpaired Records from One of the Join Files


Example: A bank wants to produce a report of inactive customer accounts. These are accounts for which there have been no recent transactions. The record layout for the transaction file was described previously in Figure 96 and the record layout was described in Figure 97. This can be done by doing the same join as detailed in Figure 100, but only retaining the unpaired records from the master file (SORTJNF2) through the use of the JOIN control statement. This is known as a right outer join.

Chapter 3. How to Use SyncSorts Data Utility Features

3.19

//* //* PRODUCE A REPORT OF INACTIVE CUSTOMERS (THOSE WITH NO TRANSACTIONS) //* FROM A MASTER FILE WITH CUSTOMER INFO, SORTED BY CUSTOMER NAME. //* //SORT1 EXEC PGM=SORT //* TRANSACTION FILE //*TRAN# TRANAMT DATE TCUSTNO //SORTJNF1 DD * 000001 0310.00 12/01/2002 2178I 000002 8055.22 12/02/2002 2123D 000003 0310.00 12/05/2002 2178I 000004 0020.00 12/06/2002 2111A 000005 0033.00 12/06/2002 7654B 000006 1225.00 12/06/2002 2166F //* //* MASTER RECORD FILE //*MCUSTNO CUSTNAME CUSTADDRESS //SORTJNF2 DD * 7654C JOSEPH SMITH NY 2111A JAMES JONES NJ 2178I JOHN JACKSON DE 2123D MARY LEE FL 0822I MICHAEL JAY CA //SORTOUT DD SYSOUT=* //SYSOUT DD SYSOUT=* //SYSIN DD * * * JOINKEYS FILE=F1,FIELDS=(TCUSTNO) * JOINKEYS FILE=F2,FIELDS=(MCUSTNO) * JOIN UNPAIRED,F2,ONLY * REFORMAT FIELDS=(F2:MCUSTNO,CUSTNAME,CUSTADDRESS) * SORT FIELDS=(CUSTNAME,A) * JOINKEYS FILE=F1,FIELDS=(27,5,A) JOINKEYS FILE=F2,FIELDS=(1,5,A) JOIN UNPAIRED,F2,ONLY REFORMAT FIELDS=(F2:1,6,7,14,21,3) SORT FIELDS=(7,13,CH,A) OUTFIL HEADER2=('INACTIVE CUSTOMERS',2/, 'CUST# ','CUSTOMER NAME ','ADD') //*

Figure 103. JCL and Required Control Statements The output from this example is:

3.20

SyncSort for z/OS 1.2 Programmers Guide

INACTIVE CUSTOMERS CUST# CUSTOMER NAME ADD 7654C JOSEPH SMITH NY 0822I MICHAEL JAY CA

Figure 104. Sample Output

Retaining Unpaired Records from Both Join Files


Example: In addition to the Inactive Customers report in the previous example, the bank can produce an exception report of all transactions for which there is no master file customer record, all within the same SyncSort execution. This is done by also including the unpaired records from the transaction file (a full outer join). The output from the join operation consists of records that either have data from the unpaired records in the transaction file or the data from the records in the master file. The missing data will be blanks in each record. These records can then be reformatted and directed into two separate output file reports, as follows.

Chapter 3. How to Use SyncSorts Data Utility Features

3.21

//* //* PRODUCE A REPORT OF INACTIVE CUSTOMERS (THOSE WITH NO TRANSACTIONS) //* FROM A MASTER FILE WITH CUSTOMER INFO, SORTED BY CUSTOMER NAME. //* ALSO SIMULTANEOUSLY PRODUCE AN EXCEPTION REPORT OF ANY TRANSACTIONS //* WHERE THE CUSTOMER NUMBER IS UNKNOWN (NO MATCHES IN THE MASTER //* FILE), SORTED BY DESCENDING TRANSACTION AMOUNT. //* //SORT2 EXEC PGM=SORT //* TRANSACTION FILE //*TRAN# TRANAMT DATE TCUSTNO //SORTJNF1 DD * 000001 0310.00 12/01/2002 2178I 000002 8055.22 12/02/2002 2123D 000003 0310.00 12/05/2002 2178I 000004 0020.00 12/06/2002 2111A 000005 0033.00 12/06/2002 7654B 000006 1225.00 12/06/2002 2166F //* //* MASTER RECORD FILE //*MCUSTNO CUSTNAME CUSTADDRESS //SORTJNF2 DD * 7654C JOSEPH SMITH NY 2111A JAMES JONES NJ 2178I JOHN JACKSON DE 2123D MARY LEE FL 0822I MICHAEL JAY CA //SORTOF1 DD SYSOUT=* //SORTOF2 DD SYSOUT=* //SYSOUT DD SYSOUT=* //SYSIN DD * * * JOINKEYS FILE=F1,FIELDS=(TCUSTNO) * JOINKEYS FILE=F2,FIELDS=(MCUSTNO) * JOIN UNPAIRED,ONLY * REFORMAT FIELDS=(F1:TRAN#,TRANAMT,DATE,TCUSTNO, * F2:MCUSTNO,CUSTNAME,CUSTADDRESS) * SORT FIELDS=(CUSTNAME,A,TRANAMT,D) * OUTFIL FILES=1,INCLUDE=(CUSTNAME,NE,C' '), INACTIVE CUSTOMERS REPT * HEADER2=(....), * OUTREC=(CUSTNAME,3X,CUSTADDRESS,3X,MCUSTNO) * OUTFIL FILES=2,INCLUDE=(TRAN#,NE,C' '), TRANSACTION EXCEPTIONS REPT * HEADER2=(....), * OUTREC=(TRAN#,3X,TRANAMT,3X,3X,DATE,3X,TCUSTNO) * JOINKEYS FILE=F1,FIELDS=(27,5,A) JOINKEYS FILE=F2,FIELDS=(1,5,A) JOIN UNPAIRED,ONLY REFORMAT FIELDS=(F1:1,7,8,8,16,11,27,6, F2:1,6,7,14,21,3)

Figure 105. JCL and Control Statements (Page 1 of 2)

3.22

SyncSort for z/OS 1.2 Programmers Guide

SORT OUTFIL

OUTFIL

FIELDS=(39,13,CH,A,8,7,CH,D) FILES=1,INCLUDE=(39,13,CH,NE,C' '), INACTIVE CUSTOMERS REPT HEADER2=('INACTIVE CUSTOMERS',2/, 'CUSTOMER NAME ',3X,'ADD',3X,'CUST# '), OUTREC=(39,14,3X,53,3,3X,33,6) FILES=2,INCLUDE=(1,6,CH,NE,C' '), TRANSACTION EXCEPTIONS REPT HEADER2=('TRANSACTION EXCEPTIONS',2/, 'TRAN# ',3X,'TRANAMT ',3X, 'DATE ',3X,'CUST# '), OUTREC=(1,7,3X,8,8,3X,16,11,3X,27,6)

//

Figure 105. JCL and Control Statements (Page 2 of 2) The SORTOF1 output from this example is:
INACTIVE CUSTOMERS CUSTOMER NAME JOSEPH SMITH MICHAEL JAY ADD NY CA CUST# 7654C 0822I

Figure 106. Sample Output The SORTOF2 output is:


TRANSACTION EXCEPTIONS TRAN# 000006 000005 TRANAMT 1225.00 0033.00 DATE 12/06/2002 12/06/2002 CUST# 2166F 7654B

Figure 107. Sample Output

Making Output Records Printable and Easy to Read


Because data is usually stored in a compact format, it can be difficult, if not impossible, to read when printed. For example, on a typical input record, there will be no blank space between fields, numeric data will sometimes be lost in leading and trailing zeros, and some data will be in unprintable format. After processing, you will probably want to edit this data so that it is easy to read. This is bound to entail one or more of the following tasks: reordering the position of record fields inserting blanks between fields inserting binary zeros converting numeric data from unprintable to printable format converting data to printable hexadecimal format

Chapter 3. How to Use SyncSorts Data Utility Features

3.23

using masks or edit patterns to insert dollar signs, decimal points, slashes, and the like. formatting the data in a record field on multiple output lines

SyncSorts OUTREC processing, specified either as a control statement or as a parameter on the OUTFIL statement, can perform these and other editing functions. The OUTREC control statement is described below. Any number of the OUTREC statements subparameters may be specified and must be coded in the order in which the fields will appear in the reformatted record. (Note that when specified as a parameter of OUTFIL,OUTREC is coded identically as for a control statement except that the keyword FIELDS is not used.) See OUTREC Control Statement Format on page 2.98 for the complete format of the OUTREC statement.

Reordering the Positions of Record Fields


Example: A data center has decided to reorder the positions of the data fields in masterfile records after sorting them. (Figure 108 gives the layout for the masterfile record.)

Figure 108. Input Record Layout To sort the records alphabetically by product name and reposition the data fields, the following is coded:

3.24

SyncSort for z/OS 1.2 Programmers Guide

//SORTPROD // //SYSOUT //* //SORTIN //SORTOUT //SORTWK01 //SYSIN SORT OUTREC

JOB EXEC DD

PGM=SYNCSORT SYSOUT=*

DD DSN=PROD.SALES,DISP=SHR DD SYSOUT=* DD SPACE=(CYL,10),UNIT=SYSDA DD * FIELDS=(7,15,CH,A) Sorts Records FIELDS=(22,3, Repositions Fields on 7,15, Output Records 1,2, 25,4, 3,4)

Gives the Jobname Identifies the Program Assigns SyncSort Messages to I/O Device Defines Input Data Set Defines Output Data Set Defines Intermediate Storage

Figure 109. JCL and Required Control Statements Figure 110 shows the output record after OUTREC processing.

Figure 110. Post-OUTREC Record Layout Explanation: After the records are sorted alphabetically by product name (7,15,CH), OUTREC processing moves the Product Code field (22,3) to the first byte of the record, the Product Name field (7,15) to the fourth byte, the Region field (1,2) to the nineteenth byte, the Months Sales field (25,4) to the twenty-first byte, and the Sales to Data field (3,4) to the twenty-fifth byte.

Chapter 3. How to Use SyncSorts Data Utility Features

3.25

Inserting Blanks and Repositioning Record Fields


Example: The central office of a commercial bank requires that each branch present its masterfile at the end of every month in the format outlined in Figure 111. Branch A, however, has formatted its masterfile records as outlined in Figure 112.

Figure 111. Required Format

Figure 112. Input Record Layout To reformat its masterfile records to conform to central office specifications, a bank branch codes the following. Since the records do not require sorting, the SyncSort copy feature is used.

3.26

SyncSort for z/OS 1.2 Programmers Guide

//FORMAT JOB // EXEC PGM=SYNCSORT //SYSOUT DD SYSOUT=* //* //SORTIN DD DSN=ACCT.MAST,DISP=SHR //SORTOUT DD SYSOUT=* //SYSIN DD * SORT FIELDS=COPY OUTREC FIELDS=(1,4, 8,10, 6X, 5,3, 1X, 18,17)

Gives the Jobname Identifies the Program Assigns SyncSort Messages to I/O Device Defines Input Data Set Defines Output Data Set Copies Records Repositions Fields on Output Records

Figure 113. JCL and Required Control Statements Figure 114 shows the effect of OUTREC processing on the output record.

Figure 114. Post-OUTREC Record Layout Explanation: After the records are copied, OUTREC specifies two types of reformatting: (1) repositioning data fields and (2) inserting blanks between fields. As shown in Figure 114, two fields have been repositioned: the Account Type field now begins on the twenty-first byte as opposed to the fifth byte, and the Account Number field begins on the fifth byte rather than on the eighth. Also, blanks have been inserted using the nX entry to specify the number (n) of blanks. Six blanks have been inserted after the Account Number field and a single blank after the Account Type field. Since the Balance field and Interest field are contiguous, they are treated as a single field in this application.

Chapter 3. How to Use SyncSorts Data Utility Features

3.27

Inserting Binary Zeros


Example: A manufacturing firm has decided to expand its product line. However, because the Item Number field on its inventory records is too small, the records must be reformatted to allow for more columns for the new products. The Item Number is kept in packeddecimal (PD) format, and the firm wants to add 4 bytes to the current 2 byte field. The new bytes are to precede the current two bytes. Figure 115 gives the input record layout.

Figure 115. Input Record Layout To copy the records and insert the 4 bytes of binary zeros, the following is coded.

//SORTCP // //SYSOUT //* //SORTIN //SORTOUT // // //SYSIN SORT OUTREC

JOB EXEC PGM=SYNCSORT DD SYSOUT=* DD DD DSN=INV.REC,DISP=SHR DSN=INV.REC.OUT,DISP=(NEW,KEEP), UNIT=SYSDA,SPACE=(TRK,5), VOL=SER=000111 DD * FIELDS=COPY FIELDS=(1,20, 4Z, 25:21,56)

Gives the Jobname Identifies the Program Assigns SyncSort Messages to I/O Device Defines Input Data Set Defines Output Data Set

Copies Records Inserts Binary Zeros & Reformats Records

Figure 116. JCL and Required Control Statements The effect of OUTREC processing is shown in Figure 117 below.

3.28

SyncSort for z/OS 1.2 Programmers Guide

Figure 117. Post-OUTREC Record Layout Explanation: The records are copied, and OUTREC processing adds 4 bytes of binary zeros (4Z) to the beginning of the Item Number field (21,2). To allow for the 4 additional bytes, the original Item Number field and the fields following it are all copied after the 4 inserted bytes of zeros.

Converting Unprintable Data to Readable Form


Example: For a file of invoice records sorted by company name, the Invoice Amount, Amount Paid, and Balance Due fields are to be converted from packed-decimal to printable format. In addition, any leading zeros will be suppressed and both commas and decimal points will be inserted. (Figure 118 gives the input record layout.)

Figure 118. Input Record Layout

Chapter 3. How to Use SyncSorts Data Utility Features

3.29

To sort the records, convert the three fields of packed-decimal data, and insert the commas and decimal points, the following is coded.

//INVOICE // //SYSOUT //* //SORTIN //SORTOUT //SORTWK01

JOB EXEC DD DD DD DD

PGM=SYNCSORT SYSOUT=* DSN=NEWINV,DISP=SHR SYSOUT=* SPACE=(CYL,5),UNIT=SYSDA

Gives the Jobname Identifies the Program Assigns SyncSort Messages to I/O Device Defines Input Data Set Defines Output Data Set Defines Intermediate Storage Sorts Records Repositions Record Fields and Converts Data

//SYSIN DD * SORT FIELDS=(1,23,CH,A) OUTREC FIELDS=(17:1,23, 52:24,4,PD,M2, 74:28,4,PD,M2, 96:32,4,PD,M2)

Figure 119. JCL and Required Control Statements The effect of OUTREC processing on the input record is shown in Figure 120 below.

Figure 120. Post-OUTREC Record Layout Explanation: First the records are sorted alphabetically by company name (1,23,CH). Then, three fields--the Invoice Amount (24,4,PD), the Amount Paid (28,4,PD), and the Balance Due (32,4,PD)--are converted from packed-decimal (PD) into readable format and editing by a SyncSort editing mask (M2) that suppresses the printing of leading zeros and inserts the appropriate commas and decimal points. The number-colon entries (c:) that precede each of the four fields assign a new starting position or, when printing, column for each of the four fields. For example, the Company Name field, which originally began in byte 1 for a length of 23 bytes, now begins in byte 17; the Invoice Amount field, which began in byte

3.30

SyncSort for z/OS 1.2 Programmers Guide

24, begins in byte 52, and so on. Note that after the data is converted and edited, the lengths of the packed-decimal fields increase from four bytes each to ten bytes and that the fields are each separated by twelve blanks.

Converting Unprintable Data to Hexadecimal Format


Example: A bank has discovered that some errors were made in recording the Account Numbers of some of its customers. Specifically, on the transaction records, some Account Number fields, which should contain only packed-decimal, PD, data, appear to contain data that is not valid packed-decimal. Figure 121 shows the input record layout.

Figure 121. Sample Input Record Layout In order to find the invalid data, the following is coded.

//SORTHEX JOB // EXEC PGM=SYNCSORT //SYSOUT DD SYSOUT=* //* //SORTIN DD DSN=TRANS.RECS,DISP=SHR //SORTOUT DD SYSOUT=* //SYSIN DD * SORT FIELDS=COPY OUTREC FIELDS=(1,30, 36:31,12,HEX)

Gives the Jobname Identifies the Program Assigns SyncSort Messages to I/O Device Defines Input Data Set Defines Output Data Set Copies Records Reformats Output Records and Converts Data

Figure 122. JCL and Required Control Statements The effect of OUTREC processing on the input record is shown in Figure 123.

Chapter 3. How to Use SyncSorts Data Utility Features

3.31

Figure 123. Sample Post-OUTREC Record Layout Explanation: The records are copied, and OUTREC processing reformats the output record to contain the Customer Name field (1,30) followed in column 36 by the Account Number field converted to hexadecimal format (31,12,HEX). Blanks are automatically inserted in the unspecified columns (31,5). Note that converting the Account Number data to printable hexadecimal expands the original 12-byte field to 24 bytes. The bank can now read the Account Number field in hexadecimal format to determine which records contain invalid data.

Converting and Editing Unprintable Data


Example: For an Outstanding Payments report, the packed-decimal Amount Due field on a companys invoice records is converted to printable format and edited with a floating dollar sign, commas, and a decimal point. In addition, to make the output easy to read, ten blanks are inserted between the Company Name field and the Amount Due field. (Figure 124 gives the input record layout.)

3.32

SyncSort for z/OS 1.2 Programmers Guide

Figure 124. Input Record Layout To sort the records and accomplish the conversion and editing, the following is coded.

//PAYMNT JOB Gives the Jobname // EXEC PGM=SYNCSORT Identifies the Program //SYSOUT DD SYSOUT=* Assigns SyncSort Messages //* to I/O Device //SORTIN DD DSN=INVOICE,DISP=SHR Defines Input Data Set //SORTOUT DD SYSOUT=* Defines Output Data Set //SORTWK01 DD SPACE=(CYL,5),UNIT=SYSDA Defines Intermediate Storage //SYSIN DD * SORT FIELDS=(1,23,CH,A) Sorts Records OUTREC FIELDS=(1,23, Converts and Edits Data 10X, and Inserts Blanks 24,4,PD,EDIT=($II,IIT.TT))

Figure 125. JCL and Required Control Statements Figure 126 shows the effect of OUTREC processing on the input record.

Chapter 3. How to Use SyncSorts Data Utility Features

3.33

Figure 126. Post-OUTREC Record Layout Explanation: First the records are sorted alphabetically by Company Name (1,23,CH). Next, OUTREC processing inserts 10 blanks (10X) between the Company Name field (1,23) and the Balance Due field (24,4,PD). OUTREC processing also converts this packed-decimal field to printable format and edits it with the user-provided pattern specified on the EDIT subparameter, EDIT=($II,IIT.TT). This pattern provides for a floating dollar sign as well as the appropriate comma and decimal point. The Is indicate that leading zeros should not be printed and the Ts indicate that zeros in those positions should be printed. Note that this conversion and editing of the data cause the length of the Balance Due field to increase from its original length of four bytes to ten bytes.

Putting a Data Field in Standard Format


Example: The date field on insurance-policy records is stored in zoned-decimal format but without slashes separating the month, day, and year. After the records are sorted, these slashes will be inserted and the date will appear in the standard mm/dd/yy format. (Figure 127 gives the input record layout.)

3.34

SyncSort for z/OS 1.2 Programmers Guide

Figure 127. Input Record Layout To sort the records and format the date field with the required slashes, the following is coded.

//SORTDT JOB // EXEC PGM=SYNCSORT //SYSOUT DD SYSOUT=* //* //SORTIN DD DSN=NEW.POLCY,DISP=SHR //SORTOUT DD SYSOUT=* //SORTWK01 DD SPACE=(CYL,5),UNIT=SYSDA //SYSIN DD * SORT FIELDS=(1,23,CH,A) OUTREC FIELDS=(1:1,23, 30:24,6,ZD,M9, 45:30,8)

Gives the Jobname Identifies the Program Assigns SyncSort Messages to I/O Device Defines Input Data Set Defines Output Data Set Defines Intermediate Storage Sorts Records Edits Data and Repositions Record Fields

Figure 128. JCL and Required Control Statements The effect of OUTREC processing is shown in Figure 129.

Chapter 3. How to Use SyncSorts Data Utility Features

3.35

Figure 129. Post-OUTREC Record Layout Explanation: The records are sorted alphabetically by Member Name (1,23,CH). The OUTREC statement repositions the Effective Date field (24,6,ZD) and the Policy Number field (30,8,ZD) in columns 30 and 45 respectively, leaving blanks between each of the three fields. In addition, the OUTREC statement edits the Effective Date field with an M9 editing mask that places slashes between the month, date, and year. Note that editing the Date field increases its size from six to eight bytes.

Converting from Variable to Fixed-Length Format


Example: In this example, there are three output files. The first is variable and the remaining two are fixed-length format. The variable output file is the standard output file from the sort. In order to convert the output from variable to fixed-length format, you should specify CONVERT on the OUTREC parameters of each of your OUTFIL control statements. The following are the JCL and control statements to effect this result.

3.36

SyncSort for z/OS 1.2 Programmers Guide

// JOB // EXEC PGM=SYNCSORT //SYSOUT DD SYSOUT=* //SORTWK01 DD SPACE=(CYL,5),UNIT=SYSDA //SORTIN DD DSN=VARIN,DISP=SHR //SORTOUT DD UNIT=SYSDA,SPACE=(CYL,(1,1)), // DISP=(,PASS),DSN=&&VAROUT //SORTOF1 DD UNIT=SYSDA,SPACE=(CYL,(1,1)), // DISP=(,PASS),DSN=&&FIX1OUT //SORTOF2 DD UNIT=SYSDA,SPACE=(CYL,(1,1)), // DISP=(,PASS),DSN=&&FIX2OUT //SYSIN DD * SORT FIELDS=(5,19,CH,A,28,2,CH,A) OUTFIL FILES=1, INCLUDE=(28,2,CH,EQ,C'92'), OUTREC=(5,19),CONVERT OUTFIL FILES=2, INCLUDE=(28,2,CH,EQ,C'93'), OUTREC=(5,19),CONVERT

Figure 130. Using the CONVERT Parameter

Printing Input Records on Multiple Output Lines


Example: In this example, five input record fields, shown in Figure 131, are copied to an output file with each field printed as a separate output line.

Figure 131. Input Record Layout Multiple output lines are created by specifying a newline character, i.e. / (slash), in the OUTREC parameter of an OUTFIL control statement. As shown in Figure 132, the newline character follows the specification of each input fields starting position and length.

Chapter 3. How to Use SyncSorts Data Utility Features

3.37

//MULTILIN JOB Gives the Jobname // EXEC PGM=SYNCSORT Identifies the Program //SYSOUT DD SYSOUT=* Assigns SyncSort Messages //* to I/O Device //SORTIN DD DSN=&&DATA,DISP=SHR Defines Input Data //* Set //SORTWK01 DD UNIT=SYSDA,SPACE=(CYL,(3,3)) Defines Intermediate //* Storage //SORTWK02 DD UNIT=SYSDA,SPACE=(CYL,(3,3)) Defines Intermediate //* Storage //SORTOUT DD SYSOUT=* Defines Output Data //* Set //SYSIN DD * SORT FIELDS=(101,40,CH,A) Sorts Records OUTFIL CONVERT, Converts Data HEADER2=('CUSTOMER ADDRESS LIST',3/), Prints a Page * Header OUTREC=(101,40,/, Prints the Data in the * Field and Starts a * New Output Line 141,25,/, As Above 166,25,/, As Above 191,30,/, As Above 266,35,2/) As Above but Starts * 2 New Output Lines

Figure 132. JCL and Control Statements for Multiline Output Once SyncSort has printed the data in the COMPANY NAME field, it starts a new output line, prints on it the data in the next field, CUSTOMER NAME, starts a new line, and so forth. After printing the contents of the last field (CITY, STATE AND ZIP), SyncSort creates two new lines (2/). Figure 133 provides an excerpt from the output file where the input record is formatted on multiple lines. A blank line appears in the second and third set of multi-line output because the corresponding input record fields (i.e. CUSTOMER TITLE and CUSTOMER NAME) were blank.

3.38

SyncSort for z/OS 1.2 Programmers Guide

CUSTOMER ADDRESS LIST

AARON'S ROD INC. DAVID LAURENCE SYS PROG 6936 YOUNGMAN BLVD. GREAT NECK

First Set of Multiline Output

CT.

06854

BLAKE'S VISION TECHNOLOGY MR. N. FRYE 261 ALBION PLACE SEA BRIGHT

Second Set of Multiline Output

NJ.

08572

COLTRANE & COMPANY DATA CENTER MANAGER 300 DORIAN AVENUE NEW YORK

Third Set of Multiline Output

NY.

11220

Figure 133. Sample Multiline Output

Dividing a Report into Sections


When printing sorted output, you may want to divide it into sections. For example, after sorting a personnel file alphabetically by company name and department, you might want to print each departments records as a separate section and leave some blank lines between each section. You might even want to print each section as a separate page of the report. SyncSort allows you to print groups of records that have identical information in one or more sort fields as sections and to separate each section by a specified number of lines or a page break. To divide output into sections, use the SECTIONS parameter on the OUTFIL control statement. For complete syntax of the SECTIONS parameter, see SECTIONS Parameter (Optional) on page 2.89.

Dividing Output into Sections


Example: A personnel roster is to be divided into sections by Department. (Figure 134 presents the layout for the input record.)

Chapter 3. How to Use SyncSorts Data Utility Features

3.39

Figure 134. Input Record Layout To sort the records and generate a list that is divided by Department, the following is coded.

//ROSTER JOB // EXEC PGM=SYNCSORT //SYSOUT DD SYSOUT=* //* //SORTIN DD DSN=PRSNL,DISP=SHR //SORTOUT DD SYSOUT=* //SORTWK01 DD SPACE=(CYL,2),UNIT=SYSDA //SYSIN DD * SORT FIELDS=(15,5,A,1,14,A),FORMAT=CH OUTFIL OUTREC=(6:15,5, 14:1,14, 33:20,3, 44:23,1, 54:24,2), SECTIONS=(15,5,SKIP=5L)

Gives the Jobname Identifies the Program Assigns SyncSort Messages to I/O Device Defines Input Data Set Defines Output Data Set Defines Intermediate Storage Sorts Records Repositions Record Fields

Sections Records

Figure 135. JCL and Required Control Statements A sample of the listing generated is shown in Figure 136.

3.40

SyncSort for z/OS 1.2 Programmers Guide

ACCTG ACCTG ACCTG ACCTG ACCTG ACCTG ACCTG

BELL EMERY JONES NORTH OWEN TWAIN WEST

PAT PAUL MARK NANCY JERRY JOAN DONNA

SUP CLK CLK MGR CLK SEC CLK

F M M F M F F

03 04 01 02 03 05 03

PRSNL PRSNL PRSNL PRSNL PRSNL

SMITHE TOWERS VREES WU YOUNG

JON LINDA GEORGE JANE RUSS

CLK CLK CLK SUP MGR

M F M F M

00 02 02 05 03

Figure 136. Sample Output Explanation: After the records are sorted alphabetically by Department (15,5) and Employee Name (1,14), they are divided into sections by department. That is, every time there is a change in the Department field (15,5 in the input record) the printer skips 5 lines (5L) before printing the next record. (Note, in the Sample Output above, the five-line break that occurs between ACCTG and PRSNL.) The OUTREC parameter is used to reposition the record fields and to leave blanks between them.

Writing Headers and Trailers for a Report


Headers are used to provide report, page, and section headings such as titles, page numbers, the current date, labels for each column of data, and the like. Similarly, trailers are used for report, page, and section summaries. You can use them, for example, to provide totals for columns of numeric data (see "Totaling and Subtotaling Data") or to indicate the end of a section with, say, a string of asterisks or to provide a list of abbreviations used in the report. To generate Headers and/or Trailers, use the HEADER and TRAILER parameters of the OUTFIL control statement. For complete syntax, see HEADER1/HEADER2 Parameters (Optional) on page 2.76 and TRAILER Parameters (Optional) on page 2.80

Writing a Title Page for a Report


Example: Marketing wants a title page for its monthly departmental sales report. The three-line title will begin on line 16 and three blank lines will separate each line of the title. The three lines will start printing in columns 49, 59, and 63, respectively. To print this title page, the following is coded:

Chapter 3. How to Use SyncSorts Data Utility Features

3.41

//DSRPT // //SYSOUT //* //SORTIN //SORTOUT //SORTWK01 //SYSIN SORT

JOB EXEC DD

PGM=SYNCSORT SYSOUT=*

DD DSN=MRKTNG.SALES,DISP=SHR DD SYSOUT=* DD SPACE=(CYL,5),UNIT=SYSDA DD * FIELDS=(1,15,CH,A) Sorts Records . . . OUTFIL HEADER1=(15/,49:'D E P A R T M E N T A L S A L E S', 4/,59:'F E B R U A R Y', 4/,63:'2 0 0 4'), Generates Title Page . . .

Gives the Jobname Identifies the Program Assigns SyncSort Messages to I/O Device Defines Input Data Set Defines Output Data Set Defines Intermediate Storage

Figure 137. JCL and Required Control Statements Figure 138 shows the header that is generated by the above HEADER1 parameter:

D E P A R T M E N T A L F E B R U A R Y 2 0 0 4

S A L E S

Figure 138. Sample HEADER1 Explanation: The HEADER1 parameter produces a header that will print on a separate page, with no page number, at the beginning of the report. The first number-slash (n/) entry, 15/, causes the printer to skip 15 lines before printing. The following number-colon entry (c:), 49:, specifies the column in which the literal string 'D E P A R T M E N T A L S A L E S' begins to print. Note that the literal string prints exactly as it is entered between the single quotes, with a space between each letter and a double space between the words. The next entry, 4/, causes the printer to skip 3 more blank lines before starting to print the literal string 'F E B R U A R Y' in column 59. Finally, three more lines are left blank (4/) and the literal string '2 0 0 4' begins printing in column 63.

3.42

SyncSort for z/OS 1.2 Programmers Guide

Writing a Page Header


Example: Marketing wants the first line of every page of its departmental sales report to contain the program number, report title, page number, and date. They want the third line of every page to contain an identifying label for each column of data. Each of these lines will begin printing in column one. To print the page header, the following is coded.

//DSRPT JOB Gives the Jobname // EXEC PGM=SYNCSORT Identifies the Program //SYSOUT DD SYSOUT=* Assigns SyncSort Messages //* to I/O Device //SORTIN DD DSN=MRKTNG.SALES,DISP=SHR Defines Input Data Set //SORTOUT DD SYSOUT=* Defines Output Data Set //SORTWK01 DD SPACE=(CYL,5),UNIT=SYSDA Defines Intermediate Storage //SYSIN DD * SORT FIELDS=(1,15,CH,A) Sorts Records . . . OUTFIL . . HEADER2=(1:'PGM NUMBER 5', 46:'DEPARTMENT SALES REPORT FOR FEBRUARY 1992', 101:'DATE:', 107:&DATE, Generates Page Heading 121:'PAGE:', 127:&PAGE,//, 1:'DEPARTMENT', 40:'SALES MANAGER', 61:'SALES REP', 78:'SALES THIS PERIOD', 103:'SALES YEAR TO DATE',//), . .

Figure 139. JCL and Required Control Statements

Figure 140 shows a representation of the header that is generated by the above HEADER2 parameter.

Chapter 3. How to Use SyncSorts Data Utility Features

3.43

PGM NUMBER 5 92 PAGE: 1 DEPARTMENT TE

DEPARTMENT SALES REPORT FOR FEBRUARY 1992

DATE: 02/01/

SALES MANAGER

SALES REP

SALES THIS PERIOD

SALES YEAR TO DA

Figure 140. Sample HEADER2 Explanation: The HEADER2 parameter produces the page header shown above. Because no forward spacing is specified, the page header begins on the first line of every page. Each of the HEADER2s number-colon entries (c:), for example, 1:, indicates the column in which the entry following the colon begins to print. Thus, the literal 'PGM NUMBER 5' is printed beginning in column 1, and so on. The &DATE and the &PAGE entries generate a current date and a consecutive page number, respectively. The date and the page number appear after the labels DATE: and PAGE:, which are specified like the other literals. The double slashes (//) following the &PAGE entry direct the printer to forward space two lines, that is, to leave one blank line, before printing the next group of literals that constitute the labels for the columns of data.

Writing a Section Header


Example: Marketing wants each section of its departmental sales report to have its own heading. The heading will consist of one line containing an identifying label for each column of data. The heading will begin printing in column one. To print the section header, the following is coded.

3.44

SyncSort for z/OS 1.2 Programmers Guide

//DSRPT JOB Gives the Jobname // EXEC PGM=SYNCSORT Identifies the Program //SYSOUT DD SYSOUT=* Assigns SyncSort Messages //* to I/O Device //SORTIN DD DSN=MRKTNG.SALES,DISP=SHR Defines Input Data Set //SORTOUT DD SYSOUT=* Defines Output Data Set //SORTWK01 DD SPACE=(CYL,5),UNIT=SYSDA Defines Intermediate Storage //SYSIN DD * SORT FIELDS=(1,15,CH,A) Sorts Records OUTFIL OUTREC=(1:1,15, Repositions Fields on Output 23:23,7, Records and Edits Data 51:48,3, 72:60,4,PD,EDIT=($II,IIT.TT), 101:64,4,PD,EDIT=($II,IIT.TT), 114:C' '), SECTIONS=(1,15,SKIP=5L, Generates Section Breaks HEADER3=(1:'DEPARTMENT', Generates Section Headings 23:'SALES MGR', 48:'SALES REP', 68:'SALES THIS PERIOD', 97:'SALES YEAR TO DATE',//))

Figure 141. JCL and Required Control Statements Figure 142 shows the header that is generated by the above HEADER3 subparameter.

Chapter 3. How to Use SyncSorts Data Utility Features

3.45

DEPARTMENT OVER COUNTER OVER COUNTER OVER COUNTER OVER COUNTER OVER COUNTER

SALES MGR CASEY CASEY CASEY CASEY CASEY

SALES REP 075 093 084 090 095

SALES THIS PERIOD $14,000.00 13,550.00 11,755.00 12,250.00 13,075.00

SALES YEAR TO DATE $27,000.00 32,000.00 24,850.00 25,000.00 26,180.00

DEPARTMENT SURGICAL SURGICAL SURGICAL SURGICAL . . .

SALES MGR. KILDARE KILDARE KILDARE KILDARE . . .

SALES REP 003 007 009 004 . . .

SALES THIS PERIOD $11,750.00 $14,300.00 11,110.00 13,375.00 . . .

SALES YEAR TO DATE $25,320.00 24,900.00 30,850.00 27,505.00 . . .

Figure 142. Sample Sections with HEADER3 Explanation: The HEADER3 subparameter on the SECTIONS parameter generates a header that prints at the beginning of each section. Its primary purpose here is to provide labels for the columns of data that appear in each section. Each of the number-colon entries (c:) specifies the column in which the entry following it should begin to print. Thus, the literal string 'DEPARTMENT' begins to print in column 1, the literal string 'SALES MGR' begins to print in column 23, and so on. Blanks are automatically inserted in the space between the columns that are specified. On the OUTREC parameter a blank has been inserted in column 114 (114:C' ') so that the output record length will equal that of the header. Note that if the HEADER3 in this example were used in conjunction with the preceding HEADER2 example, there would be no need to specify the labels for the columns of data in the HEADER2.

Using a Header to Eliminate Duplicate Information within a Section


Example: Rather than repeat the department name and sales manager, which are identical for every record included in a section of the departmental sales report, marketing wants this information to appear only once-within the section headers of the report. Therefore, the section headers first two entries (Department and Sales Manager) will be drawn directly from the first data record in each section.

3.46

SyncSort for z/OS 1.2 Programmers Guide

To print the section header with the input data fields, the following is coded.

//DSRPT JOB Gives the Jobname // EXEC PGM=SYNCSORT Identifies the Program //SYSOUT DD SYSOUT=* Assigns SyncSort Messages //* to I/O Device //SORTIN DD DSN=MRKTNG.SALES,DISP=SHR Defines Input Data Set //SORTOUT DD SYSOUT=* Defines Output Data Set //SORTWK01 DD SPACE=(CYL,5),UNIT=SYSDA Defines Intermediate Storage //SYSIN DD * SORT FIELDS=(1,15,CH,A) Sorts Records . . . OUTFIL..., Repositions Fields on Output OUTREC=(25:48,3, Records and Edits Data 37:60,4,PD,EDIT=($II,IIT.TT), 56:64,4,PD,EDIT=($II,IIT.TT), 71:C' '), SECTIONS=(1,15,SKIP=2L, Generates Section Breaks HEADER3=(1:1,15, Generates Section Headings 16:23,7, 23:'SALES REP', 34:'SALES THIS PERIOD', 54:'SALES YEAR TO DATE'))

Figure 143. JCL and Required Control Statements Figure 144 shows the header that is generated by the above HEADER3 subparameter.

OVER COUNTER

CASEY

SALES REP 075 093 084 090 095 SALES REP 003 007 009 004 . . .

SALES THIS PERIOD $14,000.00 $13,550.00 $11,755.00 $12,250.00 $13,075.00 SALES THIS PERIOD $11,750.00 $14,300.00 $11,110.00 $13,375.00 . . .

SALES YEAR TO DATE $27,000.00 $32,000.00 $24,850.00 $25,000.00 $26,180.00 SALES YEAR TO DATE $25,320.00 $24,900.00 $30,850.00 $27,505.00 . . .

SURGICAL

KILDARE

Figure 144. Sample Sections with HEADER3 Including Data from Input Record Explanation: The HEADER3 subparameter on the SECTIONS parameter generates a header that prints at the beginning of each section. Its primary purpose here is to provide

Chapter 3. How to Use SyncSorts Data Utility Features

3.47

individualized section headings that contain the Department Name and the Sales Manager from the records in that section as well as labels for the columns of data. The first two entries in this header, 1:1.15 and 16:23,7 (the Department Name and Sales Manager, respectively), are drawn directly from the input record to eliminate the repetition of these fields in the detail lines of each section. Note that specifying these fields in the HEADER3 eliminates the need to include them in OUTREC processing as was necessary in the preceding example. Each of the number-colon entries (c:) specifies the column in which the entry following it should begin to print. Thus, the Department field, (1,15) begins to print in column 1; the Sales Manager field, in column 16; the literal string "SALES REP", in column 48, and so on. Blanks are automatically inserted in the space between the columns that are specified. It should be pointed out that on the OUTREC parameter a blank has been inserted in column 71 (71:C' ') so that the output record length will equal that of the header.

Writing a Report Trailer or Summary


Example: The final page of marketings departmental sales report will contain a note saying that February sales figures include residual 1992 sales not previously recorded. This note will begin on the 21st line of the page and start printing in the 33rd column of the page. To print the report trailer, the following is coded.

//DSRPT JOB Gives the Jobname // EXEC PGM=SYNCSORT Identifies the Program //SYSOUT DD SYSOUT=* Assigns SyncSort Messages //* to I/O Device //SORTIN DD DSN=MRKTNG.SALES,DISP=SHR Defines Input Data Set //SORTOUT DD SYSOUT=* Defines Output Data Set //SORTWK01 DD SPACE=(CYL,5),UNIT=SYSDA Defines Intermediate Storage //SYSIN DD * SORT FIELDS=(1,15,CH,A) Sorts Records . . . OUTFIL . . . TRAILER1=(20/, Generates Report Trailer 33:'FEBRUARY SALES FIGURES INCLUDE RESIDUAL 1992', 'SALES NOT PREVIOUSLY RECORDED')

Figure 145. JCL and Required Control Statements Figure 123 shows the trailer that is generated by the above TRAILER1 parameter.

3.48

SyncSort for z/OS 1.2 Programmers Guide

FEBRUARY SALES FIGURES INCLUDE RESIDUAL 1992 SALES NOT PREVIOUSLY RECORDED

Figure 146. Sample TRAILER1 Explanation: The TRAILER1 parameter produces a report trailer or summary that constitutes the final page of a report. Unless otherwise specified, it begins on the first line of the page. The TRAILER1s initial number-slash (n/) entry, 20/, directs the printer to forward space 20 blank lines before printing on the 21st line. The next entry, a number-colon (c:) entry, is used to center the literal string that follows it by having the string of characters begin printing in the appropriate column. It specifies column 33 as the beginning position for printing the literal string, 'FEBRUARY SALES FIGURES INCLUDE RESIDUAL 1992 SALES NOT PREVIOUSLY RECORDED'.

Writing a Page Trailer


Example: Marketing wants the last line on every page of its departmental-sales report to contain a note identifying the information as confidential. This line will begin printing in column one. To print the page trailer, the following is coded.

//DSRPT JOB Gives the Jobname // EXEC PGM=SYNCSORT Identifies the Program //SYSOUT DD SYSOUT=* Assigns SyncSort Messages //* to I/O Device //SORTIN DD DSN=MRKTNG.SALES,DISP=SHR Defines Input Data Set //SORTOUT DD SYSOUT=* Defines Output Data Set //SORTWK01 DD SPACE=(CYL,5),UNIT=SYSDA Defines Intermediate Storage //SYSIN DD * SORT FIELDS=(1,15,CH,A) Sorts Records . . . OUTFIL . . . TRAILER2=(5'*','C O N F I D E N T I A L I N F O R M A T I O N', 5'*','C O N F I D E N T I A L I N F O R M A T I O N',5'*') . . Generates Page Trailer .

Figure 147. JCL and Required Control Statements Figure 148 shows the trailer that is generated by the above TRAILER2 parameter.

Chapter 3. How to Use SyncSorts Data Utility Features

3.49

*****CONFIDENTIAL INFORMATION*****CONFIDENTIAL INFORMATION*****

Figure 148. Sample TRAILER3 Explanation: The TRAILER2 coded above provides a trailer that appears at the bottom of every logical page. The first entry, 5'*', a literal enclosed in single quotes (in this case an asterisk) and a repetition factor (5), specifies that 5 asterisks should be printed. Because no column was specified, the trailer begins in column one. The next entry, 'C O N F I D E N T I A L I N F O R M A T I O N ', specifies that the literal string enclosed in the single quotes should directly follow the asterisks. Note that the literal string is printed exactly as it is coded within the quotation marks. That is, there is a blank between every letter and two blanks between each word. The trailers other entries specify the printing of another five asterisks followed by the literal string 'C O N F I D E N T I A L I N F O R M A T I O N ' and finally another five asterisks.

Totaling and Subtotaling Data


Writing a summary or trailer for a report will sometimes involve providing totals for columns of figures. For example, you would probably want a trailer for an inventory report to contain the total number of items on hand. The OUTFIL statement allows you to write trailers that contain both totals and subtotals. Moreover, you can total data at the end of a report, at the end of a page, and also at the end of a section. To generated total and subtotals, use the TOTAL and SUBTOTAL entries of OUTFILs TRAILER parameters and subparameter. For details of syntax, see TRAILER Parameters (Optional) on page 2.80

Totaling Data at the End of a Report


Example: The departmental sales reports final page will be a summary containing both the total for the sales this period and the total for the sales to date. The trailer will begin on the 21st line of the page and each total will have an identifying label. To print the report trailer, the following is coded.

3.50

SyncSort for z/OS 1.2 Programmers Guide

DSN=MRKTNG.SALES, DISP=SHR //SORTOUT DD SYSOUT=* Defines Output Data Set //SORTWK01 DD SPACE=(CYL,5), Defines Intermediate Storage UNIT=SYSDA //SYSIN DD * SORT FIELDS=(1,15,CH,A) Sorts Records . . . OUTFIL. . . TRAILER1=(20/, Generates Report Trailer with Totals 40:'SALES THIS PERIOD:', 59:TOT=(24,4,PD,EDIT=($II,IIT.TT)), 73:'SALES TO DATE:', 88:TOT=(28,4,PD,EDIT=($II,IIT.TT)))

//DSRPT // //SYSOUT //* //SORTIN

JOB EXEC DD DD

PGM=SYNCSORT SYSOUT=*

Gives the Jobname Identifies the Program Assigns SyncSort Messages to I/O Device Defines Input Data Set

Figure 149. JCL and Required Control Statements Figure 150 shows the trailer that is generated by the above TRAILER1 parameter.

SALES THIS PERIOD: $35,807.85

SALES TO DATE: $62,305.25

Figure 150. Sample TRAILER1 Explanation: The TRAILER1 parameter produces a report trailer or summary that constitutes the final page of a report. Unless otherwise specified, it begins on the first line of the page. This TRAILER1s initial number-slash(n/) entry, 20/, directs the printer to forward space 20 blank lines before printing. The next entry, a number-colon (c:) entry, is used to center the literal string that follows it by having the string of characters begin printing in the appropriate column. It specifies column 40 as the beginning position for the literal string 'SALES THIS PERIOD:' that labels the numeric data following it. This TRAILERs other number-colon plus literal-string entry functions the same way. The two TOT entries, TOT=(....), generate the trailers totals. These entries specify the numeric data used and its format. Thus the four bytes of packed-decimal data that begin in byte 24 (24,4,PD) and the four bytes that begin in byte 28 (28,4,PD) of the input record are converted to printable format. This data is then edited by the EDIT pattern ($II,IIT.TT), which suppresses the printing of leading zeros and inserts a floating dollar sign as well as a necessary comma and decimal point. The pattern uses an I to indicate those zeros in the total that should not be printed and a T to indicate those that should.

Chapter 3. How to Use SyncSorts Data Utility Features

3.51

Note: Be sure to code all the necessary parentheses when using the TOTAL and EDIT entries.

Subtotaling Data at the End of a Page


Example: The page trailer for a report listing invoices is to contain the totals for the Amount Paid and the Balance Due fields of the invoice records printed up to and including that page. These totals will appear directly below the columns of figures and be separated from them by strings of hyphens. An identifying label, TOTALS:, will appear on the same line as the totals and will begin in column 40. To generate the trailer, the following is coded.

//INVLST // //SYSOUT //* //SORTIN //SORTOUT //SORTWK01 //SYSIN SORT

JOB EXEC DD

Gives the Jobname Identifies the Program Assigns SyncSort Messages to I/O Device DD DSN=INVOICE,DISP=SHR Defines Input Data Set DD SYSOUT=* Defines Output Data Set DD SPACE=(CYL,5),UNIT=SYSDA Defines Intermediate Storage DD * FIELDS=(9,23,A,36,2,A,32,4,A), Sorts Records FORMAT=CH PGM=SYNCSORT SYSOUT=*

. . . OUTFIL. . . TRAILER2=(65:10'-', 86:10'-',/, Generates Page Trailer 40:'TOTALS:', with Running Totals 65:SUB=(46,4,PD,EDIT=($II,IIT.TT)), 86:SUB=(54,4,PD,EDIT=($II,IIT.TT)))

Figure 151. JCL and Required Control Statements Figure 152 shows the trailer that is produced.

3.52

SyncSort for z/OS 1.2 Programmers Guide

. . . MERLINS TRUST CO MEWER COLLEGE NORTHEAST INDUST PARK PLACE CORP PATIO PRODUCTS PINES ASSOCIATES POLL DATA CORP PRIESTLEY METALS REGENCY TRUST CO REPUBLIC DATA RIBBIT TECHNOLOGIES RICE FEATURES RICE FEATURES RICE FEATURES ROBINS NEST CORP SIDNEY COLLEGE SIDNEY COLLEGE

. . . 82124054 83013324 83013303 83022211 83022203 83022587 82124019 83022201 82124011 83013306 82124020 82124015 83013298 83022198 83013353 82124016 83013297

. . . 12/15/92 1/17/92 1/17/92 2/15/92 2/15/92 2/15/92 12/15/92 2/15/92 12/15/92 1/17/92 12/15/92 12/15/92 1/17/92 2/15/92 1/17/92 12/15/92 1/17/92 TOTALS:

. . . 0.00 0.00 200.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 750.00 0.00 0.00 0.00 0.00 0.00 ------$6,150.00

. . . 1,500.00 1,500.00 200.00 650.00 850.00 750.00 600.00 1,600.00 1,500.00 1,100.00 360.00 750.00 1,500.00 1,500.00 900.00 5,000.00 2,500.00 ---------$66,475.00

Figure 152. TRAILER2 with SUBTOTAL Explanation: The above TRAILER2 provides for totaling the figures in the Amount Paid field (46,4,PD) and the Amount Due field (54,4,PD) on the invoice records. Because the SUB (SUBTOTAL) entry is specified, the totals that appear at the bottom of each page represent running totals, that is, the totals for all the records that have been printed up to and including that page. The TRAILER2 also generates the identifying label TOTALS: (40:'TOTALS:') and strings of hyphens at the bottoms of the columns to be totaled (65:10'-', 86:10'-'). The totaled data for each field is converted to printable format and, after being edited, begins printing in the columns specified with the two number colon entries (c:), 65: and 86:. The data is edited by the EDIT pattern, ($II,IIT.TT), which suppresses the printing of leading zeros and inserts a floating dollar sign as well as the necessary comma and decimal point. The pattern uses an I to indicate the zeros in the total that should not be printed and a T to indicate those that should.

Totaling Data at the End of a Section


Example: The section trailer for an accounts receivable report sectioned by month is to contain the totals for the Amount Paid and the Balance Due columns of each section. These totals will appear directly below the columns of figures and be separated from them by strings of hyphens. An identifying label, TOTALS:, will appear on the same line as the totals and will begin in column 40. To generate the trailer, the following is coded.

Chapter 3. How to Use SyncSorts Data Utility Features

3.53

//ACTREC JOB Gives the Jobname // EXEC PGM=SYNCSORT Identifies the Program //SYSOUT DD SYSOUT=* Assigns SyncSort Messages //* to I/O Device //SORTIN DD DSN=NEW.INV,DISP=SHR Defines Input Data Set //SORTOUT DD SYSOUT=* Defines Output Data Set //SORTWK01 DD SPACE=(CYL,5),UNIT=SYSDA Defines Intermediate Storage //SYSIN DD * SORT FIELDS=(9,23,A,36,2,A,32,4,A), Sorts Records FORMAT=CH . . . OUTFIL. . . SECTIONS=(32,4,SKIP=3L, Generates Section Breaks TRAILER3=(65:10'-',86:10'-',/, Generates Section Trailer 40:'TOTALS:', with Totals 65:TOT=(46,4,PD,EDIT=($II,IIT.TT)), 86:TOT=(54,4,PD,EDIT=($II,IIT.TT))))

Figure 153. JCL and Required Control Statements Figure 154 shows the section trailer, with totals, that is produced.

3.54

SyncSort for z/OS 1.2 Programmers Guide

. . . WINIFRED INDUST

. . . 82124013 TOTALS:

. . . 12/15/91

. . . 300.00 --------$2,600.00 0.00 0.00 0.00 0.00 0.00 0.00 2,000.00 0.00 0.00 2,000.00 0.00 0.00 200.00 0.00 0.00 0.00 0.00 200.00 0.00 0.00 0.00 ---------$4,400.00

. . . 350.00 ---------$19,770.00 7,500.00 1,100.00 950.00 850.00 550.00 550.00 3,000.00 600.00 2,500.00 3,000.00 1,500.00 1,500.00 200.00 1,100.00 1,500.00 900.00 2,500.00 200.00 650.00 1,500.00 650.00 --------$32,800.00

ARLINE FRAGRANCES CHARACTER DATA COUNTRY INDUSTRIAL DUNHAM INDUST INC ECHO LABS INC ESS SECURITIES EVERMORE INDUST GOODEY FOODS GROSS BOOKS CO HARVEY MOTORS CO KALABRA CORPORATION MEWER COLLEGE NORTHEAST INDUST REPUBLIC DATA RICE FEATURES ROBINS NEST CORP SIDNEY COLLEGE SOUTHWEST INDUST SPENSERS INDUST UNITED INTERESTS INC WINIFRED INDUST

83013304 83013343 83013557 83013302 83013300 83013311 83013556 83013356 83013264 83013301 83013555 83013324 83013303 83013306 83013298 83013353 83013297 83013503 83013989 83013309 83013299

1/17/92 1/17/92 1/17/92 1/17/92 1/17/92 1/17/92 1/17/92 1/17/92 1/17/92 1/17/92 1/17/92 1/17/92 1/17/92 1/17/92 1/17/92 1/17/92 1/17/92 1/17/92 1/17/92 1/17/92 1/17/92

TOTALS:

Figure 154. TRAILER3 with TOTAL Explanation: In addition to generating strings of hyphens at the bottom of the columns to be totaled (65:10'-',86:10'-') and the identifying label TOTALS: on the line below (40:'TOTALS:'), the TRAILER3 provides for totaling the figures in the Amount Paid field (46,4,PD) and the Amount Due field (54,4,PD) on the invoice records. Note that because the TOT (TOTAL) entry is specified, the totals that appear at the end of each section represent that totals only for the records that are included in that section. The totaled data for each field is converted to printable format and, after being edited, begins printing in the columns specified with the two number colon entries (c:), 65: and 86:. The data is edited by the EDIT pattern, ($II,IIT.TT), which suppresses the printing of leading zeros and inserts a floating dollar sign as well as the necessary comma and decimal point. The pattern uses an I to indicate the zeros in the total that should not be printed and a T to indicate those that should.

Chapter 3. How to Use SyncSorts Data Utility Features

3.55

Obtaining Maximum, Minimum and Average Data


A report may need to include maximum, minimum, and average data. The parameters provided for this type of reporting are MIN, SUBMIN, MAX, SUBMAX, AVG and SUBAVG. The syntax is the same as for TOTAL and SUBTOTAL. See Totaling and Subtotaling Data on page 3.50 and TRAILER Parameters (Optional) on page 2.80.

Printing Maximum, Minimum and Average Data in Section Trailers


Example: The section trailers for an accounts receivable report sectioned by data group (AAA, BBB, etc.) are to contain six edited numeric values for a 6-byte field that begins at byte 8 (8,6). The values to be printed are the following: The minimum data value up to that point in the report (SUBMIN) The minimum data value in the section (MIN) The maximum data value up to that point in the report (SUBMAX) The maximum data value in the section (MAX) The average data value up to that point in the report (SUBAVG) The average data value in the section (AVG)

Each value will be preceded, on the same line, by appropriate identifying text. Two columns of data will be printed. To print the report, the following is coded:

SORT FIELDS=(1,3,CH,A,5,2,CH,A) SORT DATA BY GROUP AND SECTION OUTFIL FILES=(OUT), SECTIONS=(1,3,SKIP=3L, HEADER3=(3:'GROUP',2X,1,3,/,16:'SECTION',6X,'VALUE',/), TRAILER3=(//,4:'MINIMUM VALUE TO THIS POINT= ', 35:SUBMIN=(8,6,ZD,M2),/, 4:'MINIMUM VALUE FOR THIS GROUP= ', 35:MIN=(8,6,ZD,M2),//, 4:'MAXIMUM VALUE TO THIS POINT= ', 35:SUBMAX=(8,6,ZD,M2),/, 4:'MAXIMUM VALUE FOR THIS GROUP= ', 35:MAX=(8,6,ZD,M2),//, 4:'AVERAGE VALUE TO THIS POINT= ', 35:SUBAVG=(8,6,ZD,M2)/, 4:'AVERAGE VALUE FOR THIS GROUP= ', 35:AVG=(8,6,ZD,M2))), OUTREC=(18:5,2,26:8,6,ZD,M2,80:1X)

The following shows two sections from the report, with the resulting values for subminimums, minimums, submaximums, maximums, subaverages and averages:

3.56

SyncSort for z/OS 1.2 Programmers Guide

GROUP

AAA SECTION 01 01 01 02 02 02 03 03 03 VALUE 38.42 923.12 8,756.33 9,723.63 67.43 175.66 645.83 673.41 23.71 23.71 23.71 9,723.63 9,723.63 2,336.39 2,336.39

MINIMUM VALUE TO THIS POINT= MINIMUM VALUE FOR THIS GROUP= MAXIMUM VALUE TO THIS POINT= MAXIMUM VALUE FOR THIS GROUP= AVERAGE VALUE TO THIS POINT= AVERAGE VALUE FOR THIS GROUP= GROUP BBB SECTION 01 01 01 02 02 02 03 03 03 VALUE 0.01 456.11 874.01 4,354.00 2,583.54 3.57 809.01 934.53 853.21

MINIMUM VALUE TO THIS POINT= MINIMUM VALUE FOR THIS GROUP= MAXIMUM VALUE TO THIS POINT= MAXIMUM VALUE FOR THIS GROUP= AVERAGE VALUE TO THIS POINT= AVERAGE VALUE FOR THIS GROUP=

0.01 0.01 9,723.63 4,354.00 1,771.97 1,207.55

Explanation: The SECTION parameter generates a section break on field 1,3, which identifies data groups (AAA, BBB, etc.). The HEADER3 parameter defines section headers that print the label "GROUP" followed by the data group identifier. HEADER3 also defines two column headings: "SECTION," which identifies the column containing section numbers, and "VALUE," which identifies the columns containing the numeric data.

Chapter 3. How to Use SyncSorts Data Utility Features

3.57

The TRAILER3 subparameters are SUBMIN, MIN, SUBMAX, MAX, SUBAVG and AVG. They specify the six values to appear in the section trailer. The values are all derived from the same field (8,6) and are suitably edited with mask M2 (8,6,ZD,M2). The OUTREC parameter places the two data fields (5,2 and 8,6) in the report and edits the 8,6 field in the same way as for the six values in the section trailer (8,6,ZD,M2). The blank space placed at position 80 (80:1X) ensures that the output record is long enough to contain the header records.

Counting Data Records


Trailers in a report will sometimes require you to obtain a record count or a count for a particular type of item in a specific part of a report. The OUTFIL statement allows you to write trailers that contain such a count as well as cumulative, or running, counts of records. Moreover, you can obtain these counts at the end of a report, at the end of a page, and at the end of a section. To generate these counts, use the COUNT and SUBCOUNT subparameters (or COUNT15 and SUBCOUNT15). These subparameters can be used in conjunction with all other TRAILER entries. For syntax of COUNT and SUBCOUNT (as well as COUNT15 and SUBCOUNT15), see TRAILER Parameters (Optional) on page 2.80.

Obtaining a Count of Data Records


Example: Marketing wants a count of the total number of customers with outstanding payments included in the summary of its outstanding invoices report. To get this record count and print it as part of the report summary, the following is coded.

3.58

SyncSort for z/OS 1.2 Programmers Guide

//INVLST JOB Gives the Jobname // EXEC PGM=SYNCSORT Identifies the Program //SYSOUT DD SYSOUT=* Assigns SyncSort Messages //* to I/O Device //SORTIN DD DSN=INVOICE,DISP=SHR Defines Input Data Set //SORTOUT DD SYSOUT=* Defines Output Data Set //SORTWK01 DD SPACE=(CYL,5),UNIT=SYSDA Defines Intermediate Storage //SYSIN DD * SORT FIELDS=(1,23,CH,A) Sorts Records . . . OUTFIL. . . TRAILER1=(20/, Generates Report Summary 40:'NUMBER OF CUSTOMERS WITH OUTSTANDING PAYMENTS:', COUNT)

Figure 155. JCL and Required Control Statements Figure 156 shows the trailer containing the record count.

NUMBER OF CUSTOMERS WITH OUTSTANDING PAYMENTS:

52

Figure 156. Report Trailer Containing Record Count Explanation: Since each record in the report represents an individual customer, coding the COUNT entry in the TRAILER1 will provide the total number of customers with outstanding payments. This TRAILER1 produces a report trailer, or summary, that constitutes the final page of a report. It will print on the 21st line of the page (20/) and begin printing the literal string 'NUMBER OF CUSTOMERS WITH OUTSTANDING PAYMENTS: ' in column 40.

Obtaining a Cumulative (Running) Count of Data Records


Example: For an outstanding invoices report sectioned by month, marketing wants a cumulative, or running, count of invoices to date at the end of each section as well as a total count of each months invoices included as section trailers. To generate these record counts, the following is coded.

Chapter 3. How to Use SyncSorts Data Utility Features

3.59

//INVLST JOB Gives the Jobname // EXEC PGM=SYNCSORT Identifies the Program //SYSOUT DD SYSOUT=* Assigns SyncSort Messages //* to I/O Device //SORTIN DD DSN=INVOICE,DISP=SHR Defines Input Data Set //SORTOUT DD SYSOUT=* Defines Output Data Set //SORTWK01 DD SPACE=(CYL,5),UNIT=SYSDA Defines Intermediate Storage //SYSIN * SORT FIELDS=(28,2,ZD,A, Sorts Records 24,2,ZD,A, 1,23,ZD,A) . . . OUTFIL. . . SECTIONS=(24,6,SKIP=1L, Generates Sections with Record TRAILER3=(/ , Count & Cumulative Record Subcount 95:'MONTH''S NUMBER OF INVOICES: ',COUNT,/, 95:'NUMBER OF INVOICES TO DATE: ',SUBCOUNT))

Figure 157. JCL and Required Control Statements Figure 158 shows the trailers containing the counts of records.

3.60

SyncSort for z/OS 1.2 Programmers Guide

. . . RIBBIT TECHNOLOGIES RICE FEATURES SIDNEY COLLEGE SNAP FEATURES WEBB BROS CORP WELLINGTON IMPORTS WINIFRED INDUST

. . . 2/15/91 12/15/91 12/15/91 12/15/91 12/15/91 12/15/91 12/15/91

. . . 360.00 750.00 5,000.00 750.00 600.00 750.00 350.00

. . . 21.60 75.00 300.00 75.00 36.00 45.00 26.00 MONTH'S NUMBER OF INVOICES: 17 NUMBER OF INVOICES TO DATE: 17

ARLINE FRAGRANCES CHARACTER DATA COUNTRY INDUSTRIAL DUNHAM INDUST CO ECHO LABS INC ESS SECURITIES EVERMORE INDUST GOODEY FOODS GROSS BOOKS CO HARVEY MOTORS CO KALABRA CORP MEWER COLLEGE NORTHEAST INDUST REPUBLIC DATA RICE FEATURES ROBINS NEST CORP SIDNEY COLLEGE SOUTHWEST INDUST SPENSERS INDUST UNITED INTERESTS WINIFRED INDUST

1/17/92 1/17/92 1/17/92 1/17/92 1/17/92 1/17/92 1/17/92 1/17/92 1/17/92 1/17/92 1/17/92 1/17/92 1/17/92 1/17/92 1/17/92 1/17/92 1/17/92 1/17/92 1/17/92 1/17/92 1/17/92

7,500.00 1,100.00 850.00 850.00 550.00 550.00 3,000.00 600.00 2,500.00 3,000.00 1,500.00 1,500.00 200.00 1,100.00 1,500.00 900.00 2,500.00 200.00 650.00 1,500.00 650.00

618.75 50.75 0.00 0.00 22.00 22.00 225.00 30.00 150.00 225.00 90.00 75.00 20.00 90.75 75.00 54.00 150.00 20.00 26.00 90.00 26.00 MONTH'S NUMBER OF INVOICES: 21 NUMBER OF INVOICES TO DATE: 38

BALTIC AVENUE CORP BATHO PRODUCTS CARRINGTON OIL CDR TRUST INC ECHO LABS INC ESS SECURITIES FASTEROOT EQUIP FEDERAL FABRICS . . .

2/15/92 2/15/92 2/15/92 2/15/92 2/15/92 2/15/92 2/15/92 2/15/92 . . .

650.00 850.00 1,600.00 1,500.00 550.00 550.00 1,700.00 1,750.00 . . .

29.25 51.00 64.00 75.00 22.00 22.00 76.50 70.00 . . .

Figure 158. TRAILER3 Containing Record Counts and Cumulative Record Counts Explanation: The trailers first / entry causes the printer to leave one blank line after the data records and before printing the trailer. The second / entry indicates the end of the trailers first line. The identical number-colon entries (95:) set the starting positions of the literal strings that follow them: 'MONTH' 'S NUMBER OF INVOICES: ' and 'NUMBER OF

Chapter 3. How to Use SyncSorts Data Utility Features

3.61

INVOICES TO DATE: '.(Note that the apostrophe in MONTH'S is doubled because a single apostrophe would signal the end of a literal string.) Finally, because each data record in this report represents an invoice, the TRAILER3s COUNT entry generates a count of each months invoices and the SUBCOUNT entry generates a cumulative, or running, count of the invoices. The leading zeros in these 8-byte fields are suppressed.

Creating Multiple Output Files


Data centers often use the same masterfile for different purposes. Assume, for example, that you wanted to produce two reports using a masterfile of cash-receipt records. One report was to present the total cash receipts for the current month; the second, for the year to date. This would typically entail running a separate sort for each report. SortWriters multiple-output feature, however, enables you to produce both reports with a single pass of the sort. In addition, you can specify the same or different devices to receive the separate output files. Note: All the output files will be sequenced in the same way, as specified on the SORT or MERGE statement. If you need to sort the output files differently, you should use PipeSort, a Syncsort product that works with SyncSort for z/OS to reduce total elapsed time by generating multiple, differently sequenced output files from a single read of the input data. To generate multiple output files, code the OUTFIL statement. For syntax of the OUTFIL control statement, see OUTFIL Control Statement on page 2.66.

Generating Several Output Files with Different Information


Example: Marketing wants three output files of customer records. The first will contain a list of U.S. and European customers. The second will contain a list of U.S. customers only, and the third will contain a list of European customers only. To generate the three separate files, the following is coded.

3.62

SyncSort for z/OS 1.2 Programmers Guide

//CUSTRCD // //SYSOUT //* //SORTIN // // //SORTOF1 // //* // //SORTOF2

JOB EXEC DD DD

PGM=SYNCSORT SYSOUT=A DSN=SALES.RECORDS, VOL=SER=DISK1, DISP=SHR DSN=SORTED.CUSTM.RECORDS, UNIT=TAPE,VOL=SER=112231,

Gives the Jobname Identifies the Program Assigns SyncSort Messages to I/O Device Defines Input Data Set

DD

Defines First Output Data Set Containing All Customer Records

DISP=(NEW,KEEP) DSN=SORTED.DCUSTM.RECORDS, Defines Second Output Data Set Containing Domestic // UNIT=TAPE,VOL=SER=112232, Customer Records Only // DISP=(NEW,KEEP) //SORTOF3 DD DSN=SORTED.ECUSTM.RECORDS, Defines Third Output Data //* Set Containing European // UNIT=TAPE,VOL=SER=112233, Customers Only // DISP=(NEW,KEEP) //SORTWK01 DD SPACE=(CYL,20),UNIT=SYSDA Defines Intermediate Storage //SORTWK02 DD SPACE=(CYL,20),UNIT=SYSDA Defines Intermediate Storage //SORTWK03 DD SPACE=(CYL,20),UNIT=SYSDA Defines Intermediate Storage //SYSIN DD * SORT FIELDS=(10,15,CH,A) Sorts Records OUTFIL FILES=1, OUTFIL Statement for SORTOF1 INCLUDE=ALL Including All Records OUTFIL FILES=2, OUTFIL Statement for SORTOF2 INCLUDE=(67,3,CH,EQ,C'USA') Including USA Records OUTFIL FILES=3, OUTFIL Statement for SORTOF3 INCLUDE=(67,3,CH,EQ,C'EUR') Including Eur. Records DD

Figure 159. JCL and Required Control Statements Explanation: Creating the three requested output files requires coding three SORTOFxDD statements in the JCL: SORTOF1, SORTOF2, and SORTOF3 as well as three OUTFIL statements. Each of the OUTFIL statements is connected by a FILES parameter to one of the output files defined in the JCL. Specifying 1 on the FILES parameter connects its OUTFIL statement with the output file defined by the SORTOF1 DD statement in the JCL. Likewise, specifying 2 connects its OUTFIL statement with the output file defined by SORTOF2, and so on. The first output file will contain all the records from the input file (INCLUDE=ALL). The second output file will include only those records that contain the character string 'USA' beginning in byte 67, (INCLUDE=(67,3,CH,EQ,C'USA')), which indicates that these records are for USA customers. And similarly, the third output file will include only those records that contain the character string 'EUR' beginning in byte 67, which indicates that these records are for European customers.

Chapter 3. How to Use SyncSorts Data Utility Features

3.63

Writing Identical Output Files to Different Devices


Example: Personnel wants a printed copy of its updated masterfile as well as copies on disk and on tape. To generate these three copies of the same file on different devices, the following is coded.

//MULTOUT JOB Gives the Jobname // EXEC PGM=SYNCSORT Identifies the Program //SYSOUT DD SYSOUT=* Assigns SyncSort Messages //* to I/O Device //SORTIN DD DSN=PERSNL.RECORDS, Defines Input Data Set // VOL=SER=DISK1, // DISP=SHR //SORTOFPR DD SYSOUT=* Defines Printed Output //* Data Set //SORTOFTP DD DSN=PERSNL.RECORDS.TAPE, Defines Tape Output Data Set // UNIT=TAPE,VOL=SER=112233, // DISP=(NEW,KEEP) //SORTOFDS DD DSN=PERSNL.RECORDS.DISK, Defines Disk Output Data Set // UNIT=DISK1,DISP=(NEW,KEEP), // SPACE=(CYL,60) //SORTWK01 DD SPACE=(CYL,20),UNIT=SYSDA Defines Intermediate Storage //SORTWK02 DD SPACE=(CYL,20),UNIT=SYSDA Defines Intermediate Storage //SORTWK03 DD SPACE=(CYL,20),UNIT=SYSDA Defines Intermediate Storage //SYSIN DD * SORT FIELDS=(1,40,CH,A) Sorts Records OUTFIL FILES=(PR,TP,DS) Creates Multiple Output

Figure 160. JCL and Required Control Statements Explanation: Creating the three copies of the updated masterfile requires coding only one OUTFIL statement with a FILES parameter. The FILES parameter instructs SyncSort to look for multiple output files defined in the JCL and to send its output to the devices specified in the SORTOFxx statements. Thus, the output that has been sorted as specified on the SORT statement (1,40,CH,A) will be sent to the printer specified in the SORTOFPR statement, to the tape volume specified in the SORTOFTP statement, and to the disk data set specified in the SORTOFDS statement.

3.64

SyncSort for z/OS 1.2 Programmers Guide

Chapter 4. JCL and Sample JCL/Control Statement Streams

SyncSorts job control statements follow the standard operating system conventions described in the z/OS job control language manuals. Each program application therefore requires a JOB statement, an EXEC statement, and a DD (data definition) statement for every data set used. (The single exception to this is the dynamic allocation of work files via DYNALLOC or DYNATAPE.) The inclusion and coding requirements of particular job control statements depend on such factors as whether SyncSort is program-invoked or initiated directly, whether any exits are coded, and, of course, whether the sorting technique requested is Disk Sort, MAXSORT, PARASORT or Tape Sort. All aspects of program initiation which are specific to the sort/merge (such as the dedicated DD names SORTIN and SORTOUT) are documented in this chapter. For complete coding instructions, refer to a z/OS MVS JCL reference manual. The following table summarizes Disk Sorts DD statement requirements.

Chapter 4. JCL and Sample JCL/Control Statement Streams

4.1

Disk Sort DD Statements //STEPLIB DD //JOBLIB DD //SYSOUT DD //SORTIN DD Instructs operating system to look for the sort program in a specified data set. Message data set. Required unless all messages are routed to console. SORT input data set. Required unless it is a join application or there is an E15 exit routine. Ignored if the invoking program supplies an inline E15 exit routine; optional if the MODS statement activates an E15 exit routine. MERGE input data set. Required unless there is an E32. Join application input data sets. Required for join application. Output data set. Required unless there is an E35. Ignored if the invoking program supplies an inline E35 exit routine; optional if the MODS statement activates an E35 exit routine. OUTFILE output data sets. One required for each FILES or FNAMES specification. Output data set of records eliminated by the SUM control statement. Required when the XSUM parameter is specified. Disk work area definition. Required unless incore sort, DYNALLOC, MERGE, COPY or restarting at a MAXSORT merge breakpoint. Control statement data set. Required unless the invoking program supplies the address of a 24-bit or a 31-bit extended parameter list. Used to override PARM or control statement information. Checkpoint data set. Required for Checkpoint-Restart. Required if user exits are in SYSIN. Required if user exits are to be linkage-edited at execution time.

//SORTINnn DD //SORTINn DD //SORTJNF1 DD //SORTJNF2 DD //SORTOUT DD

//SORTOFxx DD //SORTOFx DD //fname DD //SORTXSUM DD //SORTWKxx DD //SORTWKn DD //SYSIN DD

//$ORTPARM DD //SORTCKPT DD //SORTMODS DD //SYSLIN DD //SYSLMOD DD //SYSPRINT DD //SYSUT1 DD //ddname DD

Required for exits unless the exit is inline in LINKLIB/ JOBLIB/STEPLIB or in SYSIN.

EXEC Statement
The EXEC statement is required in order to indicate to the operating system that the job is a sort/merge application. For a Disk Sort, the format of the EXEC statement is as follows.

4.2

SyncSort for z/OS 1.2 Programmers Guide

To use a sort cataloged procedure, omit PGM= and specify the appropriate procedure name.
PGM=SYNCSORT PGM=SORT //stepname EXEC PGM=IERRCO00 [,PARM='...'] PGM=IGHRCO00 PGM=ICEMAN

Figure 161. Disk Sort EXEC Statement Format The PARM parameter may be used to pass the sort/merge program a variety of keyword parameters, modifying it to meet the needs of the individual application.

For MAXSORT, PARASORT, DB2 Query Support, and Tape Sort


The format of the EXEC statement varies with the sorting technique chosen. The MAXSORT and PARASORT PARM options are used to request the MAXSORT or PARASORT sorting technique. The DB2 PARM option is used to request the DB2 Query function. These PARMs are compatible with any of the PGM names for Disk Sort. A Tape Sort application, on the other hand, requires a PGM name of SORT, IERRCO00, IGHRCO00, or ICEMAN. When PGM=SYNCSORT is used, SORTWK must be assigned to disk. The set of available PARM options is also dependent on sorting technique. Refer to Chapter 5. PARM Options for a description of the available options.

Coding Conventions for DD Statements


The following table summarizes the standard coding conventions for DD statements as they relate to the sort/merge program. For more detailed information, refer to an z/OS job control language manual.

Chapter 4. JCL and Sample JCL/Control Statement Streams

4.3

Parameter DSNAME/DSN

Subparameter

Required? To access a labeled data set (e.g., SORTIN, STEPLIB) or to keep or catalog the data set being created (e.g., SORTOUT, SORTOU00). DCB not required for disk or standard labeled tape input.

DCB RECFM, LRECL, and BLKSIZE OPTCD and BUFOFF

To override the values in the data set label of an old data set; to override the values in the first SORTIN or SORTINnn file for a new data set. To indicate ASCII input and output.

UNIT SPACE VOLUME/VOL

For an input file that is not cataloged or passed; for a new data set For a new DASD data set. For an input file that is not cataloged or passed; for a DASD output data set to be cataloged or passed. To override (1,SL). To override (NEW,DELETE).

LABEL DISP

STEPLIB/JOBLIB DD Statement
If SyncSort has been installed in a private user library or in a test library, a STEPLIB or JOBLIB DD statement is required. The sample DD statement below instructs the operating system to look for the sort in a partitioned data set named SYNCTEST.

//STEPLIB

DD

DSN=SYNCTEST,DISP=SHR Figure 162. Sample STEPLIB DD Statement

SYSOUT DD Statement
This defines the data set for SyncSort messages.

//SYSOUT DD

SYSOUT=A Figure 163. Sample SYSOUT DD Statement

4.4

SyncSort for z/OS 1.2 Programmers Guide

If the SYSOUT DD statement is omitted, any message routed to it will be diverted to the console. Omitting the SYSOUT DD statement and setting the MSG=SC PARM (critical messages to the console, all messages to the printer), for example, will result in all messages being sent to the console.

SORTIN DD Statement
The SORTIN DD statement defines the data set to be sorted or copied. (The input file for a merge application is defined by the SORTINnn DD statement.) It is required for all sorts except those where an E15 exit (COBOL Input Procedure) provides all the input records. The SORTIN file must have physical sequential or extended sequential organization or be a member of a partitioned data set or PDSE. It may reside on any device supported by BSAM or VSAM and if it is a VSAM data set, may be key-sequenced, entry-sequenced or relative record. SORTIN data sets may also be BatchPipes or z/OS pipes or they may be HFS data sets. DCB information need not be supplied for a disk or standard labeled tape file. Any of the information accessed from a standard label can be overridden by coding the appropriate DCB parameter in the JCL. The maximum record lengths supported are 32,760 bytes for fixed-length records and 32,767 bytes for variable-length records. By default SyncSort does not accept an uninitialized SORTIN data set and will terminate processing with a WER400A message. An uninitialized data set is one that has been newly created but never successfully closed. The UNINTDS PARM or installation option can be used to change SyncSorts default mode of processing to accept an uninitialized input data set and process it as an empty file. See UNINTDS on page 5.30. In this example, the data set to be sorted/copied is named SALESIN. It resides on one reel

//SORTIN DD //

DSN=SALESIN,DISP=(OLD,KEEP), UNIT=TAPE,VOL=SER=123456 Figure 164. Sample SORTIN DD Statement

of tape whose volume serial number is 123456. SALESIN is the first data set on that tape and has a standard label. To access a SORTIN data set that resides in hiperbatch use the HBSI PARM. For more information about HBSI see Chapter 5. PARM Options. Note: The TYPE parameter on the RECORD control statement should be specified if SORTIN is VSAM. If TYPE is not provided, the SORTOUT RECFM will be examined to determine the SORTIN TYPE. If no SORTOUT RECFM is found, TYPE=V will be assumed if the SORTOUT is VSAM and TYPE=F if the SORTOUT is non-VSAM.

Chapter 4. JCL and Sample JCL/Control Statement Streams

4.5

Concatenating Input Data Sets


The SORTIN file may consist of concatenated data sets, up to the limit supported by the operating system. SyncSort must determine one set of DCB characteristics to use for reading all data sets in the concatenation. The following rules apply to the DCB characteristics: When the first data set is fixed-length (RECFM=F, FB, FBS), all subsequent data sets must be fixed-length and have the same LRECL. When the first data set is variable-length (RECFM=V, VB, VS, VBS), all subsequent data sets must be variable-length. For variable-length data sets, the LRECL of the first data set is used except for the following situations: The LRECL of a subsequent data set is used if that LRECL is the largest found and is available at sort initialization. An LRECL is available at initialization if it is specified on a SORTIN DD statement or exists in the label of a SORTIN disk data set. A record length specified via the L1 value on the RECORD control statement is used if it is the largest record length found.

For both fixed and variable-length data sets, the BLKSIZE of the first data set is used unless the BLKSIZE of a subsequent data set is the largest found and is available at sort initialization. A BLKSIZE is available at initialization if it is specified on a SORTIN DD statement or exists in the label of a SORTIN disk data set.

The following shows sample JCL for concatenating input data sets:

//SORTIN DD // // // DD // // // DD // //

DSN=AUGUST.SALES,DISP=(OLD,KEEP), UNIT=3390,VOL=SER=DISK1, DCB=(LRECL=200,RECFM=VB,BLKSIZE=7404) DSN=JUNE.SALES,DISP=(OLD,KEEP), UNIT=TAPE,VOL=SER=123456,LABEL=(2,SL), DCB=(LRECL=200,RECFM=V,BLKSIZE=8004) DSN=JULY.SALES,DISP=(OLD,KEEP), UNIT=TAPE,VOL=SER=654321,LABEL=(1,SL), DCB=(LRECL=100,RECFM=VB,BLKSIZE=8004)

Figure 165. Sample Disk and Tape Data Set Concatenation to SORTIN In the preceding example, one disk and two tape data sets have been concatenated. Any one of these data sets could be presented first. Position is not dependent upon BLKSIZE or

4.6

SyncSort for z/OS 1.2 Programmers Guide

LRECL. If the LRECL or BLKSIZE cannot be determined at SORT initialization, the first data set must carry the largest LRECL or BLKSIZE of the concatenation. Typically the LRECL or BLKSIZE cannot be determined when the input consists of concatenated tape data sets and the JCL lacks a DCB specification.

Sorting Large Input Data Sets


The MAXSORT technique is recommended for sorting very large amounts of data when disk work space is limited. With this technique, SORTWK requirements are independent of SORTIN size; thus, regardless of the size of the file, it can be sorted by one sort program using disk work files. MAXSORTs breakpoint/restart capability breaks the overlarge sorting application into smaller individual sorts; high priority jobs can execute between these smaller sorts without forcing any data to be resorted. See Chapter 9. MAXSORT.

Reducing Elapsed Time for SORTS with Multi-volume or Concatenated Tape SORTIN
The PARASORT technique can be used to improve elapsed time performance of sorts that use multi-volume or concatenated tape SORTIN data sets. See Chapter 10. PARASORT on page 10.1.

SORTINnn or SORTINn DD Statement


SORTINnn and SORTINn DD statements are used to define the input to a merge application. (Use the SORTIN DD statement to define the data set to be sorted or copied.) SORTINnn or SORTINn DD statements are required for all merge applications unless an E32 exit supplies the input data. SORTINnn and SORTINn data sets may be BatchPipes or z/OS pipes or they may be HFS data sets. It is possible to merge up to 100 data sets. Each input data set is specified on a SORTINnn or SORTINn DD statement. The valid range for n is 0 through 9; for nn, 00 through 99. If both SORTINx and a SORTIN0x are specified, they are treated as duplicates and only the first definition is processed. Each file must receive a different number. Numbers may be skipped or used out of order. There are no restrictions as to which input files are to receive which numbers. All input data sets must have the same record format (fixed or variable), and the records in each input file must already be in the desired sequence. By default, SyncSort does not accept an uninitialized SORTINnn or SORTINn data set and will terminate processing with a WER400A message. An uninitialized data set is one that has been newly created, but never successfully closed. The UNINTDS PARM or installation option can be used to change SyncSorts default mode of processing to accept an uninitialized input data set and process it as an empty file. See UNINTDS on page 5.30.

Chapter 4. JCL and Sample JCL/Control Statement Streams

4.7

//SORTIN17 // //SORTIN01 // //SORTIN24 // //

DD DD DD

DSNAME=BRANCHA.FICA,VOL=SER=131313, DISP=OLD,UNIT=3480 DSNAME=BRANCHC.FICA,VOL=SER=242424, DISP=OLD,UNIT=3390 DSNAME=BRANCHB.FICA,VOL=SER=121212, DISP=OLD,UNIT=3400-3,LABEL=(,NL), DCB=(RECFM=FB,LRECL=80,BLKSIZE=400)

Figure 166. Sample SORTINnn DD Statements (Merge) In this example, the DCB information for the first two of the three files to be merged is supplied by the file labels. In order for the merge to execute, these files must have a RECFM of F or FB, as indicated by the third files RECFM value.

SORTJNF1 and SORTJNF2 DD Statements


SORTJNF1 and SORTJNF2 DD statements are used to define the input to a join application. These statements are required for a join application. In this example, the SORTJNF1 and SORTJNF2 files are specified. The first file is a fixedlength file; the second a variable-length file.

//SORTJNF1 // // //SORTJNF2 // //

DD

DD

DSNAME=BRANCHA.FICA,VOL=SER=131313, DISP=OLD,UNIT=3480, DCB=(RECFM=FB,LRECL=80,BLKSIZE=8000) DSNAME=MASTER.FICA,VOL=SER=121212, DISP=OLD,UNIT=3390, DCB=(RECFM=VB,LRECL=200,BLKSIZE=27800)

Figure 167. Sample SORTJNF1 and SORTJNF2 DD Statements

SORTOUT, SORTOFxx, SORTOFx and SORTXSUM DD Statements


The SORTOUT, SORTOFxx, SORTOFx and SORTXSUM DD statements are used to define one or more output files. The FNAMES parameter of the OUTFIL control statement may also specify DD names of output files. All output is directed to SORTOUT unless an inline E35 exit (COBOL output procedure) assumes the full responsibility for output processing. Records eliminated by SUM processing will be written to the SORTXSUM DD statement if the XSUM option was selected on the SUM control statement. These output data sets may be directed to a BSAM or VSAM supported device, to BatchPipes or z/OS pipes, or to HFS data sets.

4.8

SyncSort for z/OS 1.2 Programmers Guide

//SORTOUT // // //SORTOF01 // //

DD

DD

DSN=MASTER.OUT,UNIT=SYSDA, DISP=(NEW,KEEP),SPACE=(TRK,10), VOL=SER=DSK002 DSN=REPORT.OUT,UNIT=SYSDA, DISP=(NEW,KEEP),SPACE=(TRK,10), VOL=SER=DSK002

Figure 168. Sample SORTOUT/SORTOFxx DD Statements In the preceding example, the missing DCB parameters except BLKSIZE will default to those assigned to SORTIN or (for a merge application) to those assigned to the last SORTINnn in the JCL stream. The DCB BLKSIZE, if missing, will be determined via system-determined blocksize when it is active or from SORTIN if SORTOUT and SORTIN LRECLs are the same, otherwise SyncSort will select an appropriate BLKSIZE. If a sort or a merge has an LRECL specified in the output DD JCL that is found to be smaller than the internally processed record length (determined from SORTIN, the LENGTH values of a RECORD statement, or an INREC statement), SyncSort processing will be controlled by the SOTRN installation option or its run time override parameter TRUNC. (SYNCGENR applications are controlled by the SOTRNGN installation option.) If the parameter setting allows truncation, SyncSort will write the records to the output data set by truncating the records to the LRECL of that data set. The delivered default allows truncation. SyncSort will not truncate records after OUTREC processing. If the option disallows truncation, a WER462A error message will be issued. If an application that is processing fixed-length data has an LRECL specified in the SORTOUT or SORTXSUM JCL that is found to be longer than the internally processed record length, SyncSort will normally pad the output records with binary zeros. See the discussion of the PAD parameter in chapter 5 for additional controls that can be applied to applications with both a SORTIN and a SORTOUT where the SORTOUT LRECL is longer than the SORTIN LRECL. This padding will be done for SORTXSUM and for SORTOUT when OUTFIL is not in use. It will not be done for any OUTFIL files. If the option disallows padding, a WER462A error message will be issued. The delivered default allows padding. If RECFM is specified and the report writing features of the OUTFIL control statement are being used, the RECFM of the output file must include the 'A' subparameter, except when the REMOVECC parameter is in use. For a COPY or MERGE, the output file must not be the same as any of the input files. Note: The TYPE parameter on the RECORD control statement should be specified if SORTIN is VSAM. If TYPE is not provided, the SORTOUT RECFM will be examined to determine the SORTIN TYPE. If no SORTOUT RECFM is found, TYPE=V will be assumed if the SORTOUT is VSAM and TYPE=F if the SORTOUT is non-VSAM.

Chapter 4. JCL and Sample JCL/Control Statement Streams

4.9

Secondary Allocation
If the automatic secondary allocation option was enabled at installation time, requesting secondary allocation on the output DD statements is not required. This feature automatically provides output space for each of the output files. To place a SORTOUT data set into hiperbatch so that subsequent job steps can access it, use HBSO. For more information about HBSO see the PARM Option chapter in this manual.

SORTWKxx or SORTWKx DD Statement


For non-MAXSORT applications, up to 255 data sets may be specified for intermediate storage when sorting. (MAXSORT, which is recommended for large sorting applications, is limited to 32 SORTWK data sets.) Each work file carries a SORTWKxx or SORTWKx name. x can be any alphanumeric or national ($, #, @) character. Each SORTWKxx or SORTWKx must be allocated on a single unit and a single volume. SORTWK data sets must have physical sequential organization and cannot be extended sequential. For performance reasons, the use of VIO for SORTWK data sets is not recommended. You can specify 3380 and/or 3390 disk devices. When device types are mixed, each device is used to full capacity. Note that although SORTWK space can be allocated in blocks, tracks, or cylinders, allocating in cylinders will yield optimal performance. The CONTIG option of the SPACE parameter should be avoided since it may delay allocation and offers no performance advantage. The SORTWKxx DD statement in the following example establishes a primary allocation of 20 cylinders of work space.

//SORTWK02

DD

UNIT=3390,SPACE=(CYL,20)

Figure 169. Sample SORTWKxx DD Statement for Disk Sorts

Secondary Allocation
There is no need to specify RLSE and a secondary allocation value on the SORTWKxx DD statement at installations that have set these defaults at SyncSort installation time.

Are SORTWKxx DD Statements Necessary?


SORTWKxx DD statements are not used for merge or copy applications. They are not required for sorts executed using the DYNALLOC option. Provided neither DYNALLOC nor FIELDS=COPY is in effect, it will be necessary to include SORTWK data sets whenever any of these conditions holds:

4.10

SyncSort for z/OS 1.2 Programmers Guide

INCORE is set to OFF. An E14 or E16 is included. Checkpoint-Restart is specified. The criteria for an incore sort are not met. (See the discussion of incore sorts in Chapter 13. Performance Considerations.) SUM, OUTREC or OUTFIL is used. SORTOUT is a VSAM data set.

Note: Sort applications that use SUM, OUTREC, OUTFIL or VSAM SORTOUT and do not provide JCL SORTWORKs may have DYNALLOC automatically enabled. This will allow the completion of a sort that would have terminated for lack of required SORTWORK space.

Initiating Tape Sort


Tape Sorts use the following devices for intermediate storage: 2400 and 3400 series tape units with densities of 800, 1600 and 6250 BPI. Each reel of tape must be full-size (2400 feet long). Tape cartridges devices (3480, 3490, 3490E and 3590) may also be used. When intermediate storage is on tape, from 3 to 32 data sets may be specified. Tape SORTWKxx files must begin with SORTWK01 and be numbered consecutively. When different device types and tape densities are mixed, the lowest density is used to calculate the capacity of each SORTWK volume. The MAXSORT technique (supporting only disk SORTWK files) is strongly recommended for large sorts. The xxxx in the UNIT parameter of the following example represents the installation-specific name used to define a tape device.

2400 //SORTWK01 DD UNIT= 3400 xxxx Figure 170. SORTWKxx DD Statement Format for Tape Sorts For more information, see Chapter 12. Tape Sort.

SYSIN DD Statement
The data set defined by the SYSIN DD statement contains SyncSort control statements. The SYSIN DD statement is required in order to initiate the sort/merge through job control language.

Chapter 4. JCL and Sample JCL/Control Statement Streams

4.11

//SYSIN DD * SORT OMIT END /*

FIELDS=(5,3,CH,A) COND=(12,6,PD,EQ,0)

Figure 171. Sample SYSIN DD Statement

$ORTPARM DD Statement
The data set defined by the $ORTPARM DD statement may contain PARM parameters and any of the sort control statements. Parameters and control statements passed via the $ORTPARM DD statement generally override all others passed, whether the sort/merge is called from a program or initiated through job control language. The $ORTPARM DD record format must be F or FB, and the record length must be 80 bytes. Labels are not allowed on $ORTPARM card images. Leading blanks are not required on a PARM card image, but at least one leading blank must precede a sort control statement keyword. The $ORTPARM data sets must be formatted in accordance with the following rules: PARM specifications included in the $ORTPARM data sets must be specified before any sort control statement specifications. PARMS must be specified without the keyword PARM= and without quotation marks. A comma in columns 2-70 of a PARM card image followed by a blank, or a comma alone in column 71, may be used to indicate that the next record is part of the current statement. However, if the PARM specification is present through column 71, a continuation character must be specified in column 72 to indicate continuation. Comments may be included on $ORTPARM card images provided there is a blank between the last PARM specification and the comment. You may continue a comment by placing a continuation character in column 72 if there are no additional PARMs. In this case, the entire next card image will be considered a comment. If additional PARMs will follow the comment, you may continue that comment by coding an asterisk (*) in column 1 of the next card image.

Note: Refer to Chapter 2. SyncSort Control Statements for additional formatting requirements.

4.12

SyncSort for z/OS 1.2 Programmers Guide

The following example of a $ORTPARM data set illustrates the conventions for defining the $ORTPARM data set.

//$ORTPARM DD * BMSG,STOPAFT=500, EQUALS SORT FIELDS=(1,8,PD,A) Figure 172. Sample $ORTPARM DD Statement The $ORTPARM data set in the previous example overrides the options set in the associated invoking program (or job control stream) to sort 500 records from the input file. These will be the first 500 records that meet whatever criteria have been set by the original application (which might include, for example, the INCLUDE/OMIT control statement). BMSG turns on the WERnnnB message set, so that the processing accorded these 500 records is fully documented. EQUALS preserves the order of equal-keyed records from input to output.

//$ORTPARM DD * BMSG,STOPAFT=500, EQUALS SUM FIELDS=(12,4,30,8,38,8), FORMAT=PD SORT FIELDS=(1,8,PD,A) Figure 173. Sample $ORTPARM DD Statement The preceding example illustrates how to include control statements more than 80 bytes long; continuation card images are indicated by a blank field following an operand-comma combination.

//SYSIN DD * OUTFIL FILES=(1,2,3), . . . //$ORTPARM DD * OUTFIL FILES=(3,4,5), . . . Figure 174. Sample $ORTPARM DD Statement

Chapter 4. JCL and Sample JCL/Control Statement Streams

4.13

In this example, the OUTFIL control statement in $ORTPARM overrides the OUTFIL control statement in SYSIN for file 3, and adds OUTFIL specifications for files 4 and 5.

$ORTPARM Processing for Century Window COBOL Applications


The $ORTPARM DD facility is particularly useful for COBOL sorts requiring century window processing of year data with SyncSorts year data formats. The year data formats are not supported by COBOL. Therefore, when a data format specification needs to be changed for century window processing, it is necessary to override SORT control statements generated by COBOL. The override can be accomplished with a $ORTPARM DD statement. The following example shows a $ORTPARM DD used for this purpose.

//$ORTPARM DD * SORT FIELDS=(10,2,Y2Z,A),CENTWIN=1980 Figure 175. Sample $ORTPARM DD Statement for Century Window Processing In this example, the 2-digit year field (10,2) will have century window processing applied to it via the Y2Z year data format and the CENTWIN option. As described in the previous section, multiple sort invocations by the same COBOL program would require multiple $ORTPARM DD statements, each with the FREE=CLOSE parameter.

$ORTPARM DD Processing for Multiple Sort Invocations


When SyncSort is to be invoked more than once in the same job step, you may need different $ORTPARM DD control data sets for each invocation. For multiple control data sets, define each one in the JCL stream, in the desired order, as a disk data set (or partitioned data set member) with the FREE=CLOSE parameter added. FREE=CLOSE will cause the first sort $ORTPARM data set to be dynamically deallocated by the first sort execution, and so forth for each sort execution. The following example shows sample JCL with two $ORTPARM DD statements:

//$ORTPARM DD // //$ORTPARM DD // . . //$ORTPARM DD //

DSN=SORT.OPTIONS(SORT1),DISP=SHR,FREE=CLOSE WILL BE USED BY FIRST SORT EXECUTION DSN=SORT.OPTIONS(SORT2),DISP=SHR,FREE=CLOSE WILL BE USED BY SECOND SORT EXECUTION

DSN=SORT.OPTIONS(SORTn),DISP=SHR,FREE=CLOSE WILL BE USED BY THE nTH SORT EXECUTION

Figure 176. Sample Multiple $ORTPARM DD Statements

4.14

SyncSort for z/OS 1.2 Programmers Guide

Processing will proceed from top to bottom of this $ORTPARM data set list. This sequence must be maintained in the JCL so that the multiple sorts can read the $ORTPARM data sets in the correct order. Multiple $ORTPARM datasets are available only in a JES2 environment. JES3 does not support the specification of multiple DD statements for the same DDNAME. The $ORTPARM DD statement for Tape Sort may include only one 80-byte record, which in turn may only feature PARMs. $ORTPARM cannot be used to override Tape Sort control statements.

SORTCKPT DD Statement
This DD statement is only used when the CKPT/CHKPT option is set on the SORT/MERGE control statement, requesting the Checkpoint-Restart feature. See Chapter 13. Performance Considerations for an explanation of this feature.

For Exit Routines that Require Link-editing at Execution Time


The following DD statements are required whenever an exit routine is to be link-edited at execution time.

SORTMODS DD Statement
The partitioned data set defined must be large enough to contain all the exit routines entered in SYSIN. For exits not entered in SYSIN, it is necessary to supply DD statements defining the libraries in which the routines reside.

//SORTMODS DD

SPACE=(CYL,(2,,4)),UNIT=SYSDA Figure 177. Sample SORTMODS DD Statement

SYSLIN DD Statement
The SYSLIN DD statement defines the temporary data set that will contain the linkage editor control statements created by SyncSort for the exit routine(s).

//SYSLIN

DD

DSN=&&TEMP,UNIT=SYSDA,SPACE=(TRK,1) Figure 178. Sample SYSLIN DD Statement

Chapter 4. JCL and Sample JCL/Control Statement Streams

4.15

SYSLMOD DD Statement
The SYSLMOD DD statement defines the temporary data set that will contain the linkedited exit module(s).

//SYSLMOD //

DD

DSN=&&TEMP2,UNIT=SYSDA, SPACE=(TRK,(10,5,2)) Figure 179. Sample SYSLMOD DD Statement

SYSPRINT DD Statement
The SYSPRINT DD statement defines the message data set for the link-editing of sort exits.

//SYSPRINT

DD

SYSOUT=A Figure 180. Sample SYSPRINT DD Statement

SYSUT1 DD Statement
The SYSUT1 DD statement is used to define the temporary data set used as a work area when SyncSort link-edits an exit routine.

//SYSUT1 //

DD

DSN=&&TEMP3,UNIT=SYSDA, SPACE=(CYL,(5,5)) Figure 181. Sample SYSUT1 DD Statement

DD Statements for MAXSORT, PARASORT, DB2 Query Support, and Tape Sort
The MAXSORT technique is initiated by means of the MAXSORT PARM, and utilizes additional MAXSORT DD statements (SORTBKPT, SORTOU00, SORTOUnn) and PARMs. With MAXSORT, SORTWK files must be allocated to disk devices. This technique is strongly recommended for very large sorting applications in a limited disk work space environment. The PARASORT technique is initiated by means of the PARASORT PARM and utilizes additional PARASORT DD statements (SORTPAR1, SORTPAR2, SORTPAR3, SORTPAR4). PARASORT requires disk SORTWK devices. This technique can improve the elapsed time of sorting applications that have multi-volume tape SORTIN data sets.

4.16

SyncSort for z/OS 1.2 Programmers Guide

The DB2 Query Support technique is initiated by means of the DB2 Query Support PARM and utilizes the DB2 Query Support DD statement SORTDBIN. This technique allows DB2 data to be passed directly into a SORT or COPY operation, without the use of setup steps or the need for user-written E15 exits. Tape Sort is initiated by assigning tape work devices. The use of Tape Sort constrains the set of PARMs available to the sort, requires a SORTLIB DD statement, and restricts the coding of the $ORTPARM and SORTWKxx statements. For detailed descriptions of these techniques see Chapter 9. MAXSORT, Chapter 10. PARASORT, and Chapter 12. Tape Sort.

Sample JCL/Control Statement Streams


The sample JCL/control statement streams in this section illustrate how to specify sort, merge and copy applications with and without exit routines. An example illustrating multiple output is also included. Refer to Chapter 3. How to Use SyncSorts Data Utility Features for comprehensive examples illustrating the data utility and report writing features. Examples of how to invoke SyncSort from a program, COBOL exit routines, MAXSORTs, PARASORTs and Tape Sorts are provided in the appropriate chapters.

Chapter 4. JCL and Sample JCL/Control Statement Streams

4.17

Sorts without Exit Routines Example 1

//SORTOMIT //SORT1 //STEPLIB //SYSOUT //SORTIN // // // //SORTOUT // // // //SORTWK01 //SORTWK02 //SORTWK03 //SORTWK04 //SORTWK05 //SYSIN SORT OMIT END /*

JOB EXEC DD DD DD

PGM=SYNCSORT,PARM='STOPAFT=1000' DSN=SORT.RESI.DENCE,DISP=SHR SYSOUT=A DSN=INPUT,UNIT=3490, VOL=SER=012345,DISP=(OLD,KEEP), DCB=(LRECL=100,RECFM=FB, BLKSIZE=32700),LABEL=(1,SL) DD DSN=OUTPUT,VOL=SER=543210, UNIT=3490,DISP=(NEW,KEEP), DCB=(LRECL=100,RECFM=FB, BLKSIZE=0),LABEL=(1,SL) DD SPACE=(CYL,(20)),UNIT=SYSDA DD SPACE=(CYL,(20)),UNIT=SYSDA DD SPACE=(CYL,(20)),UNIT=SYSDA DD SPACE=(CYL,(20)),UNIT=SYSDA DD SPACE=(CYL,(20)),UNIT=SYSDA DD * FIELDS=(1,8,CH,A) COND=(1,8,CH,EQ,C'JOHN DOE')

1 2 3 4 5

8 9 10 11 12

Figure 182. Sample JCL/Control Stream (1) 1. The JOB statement gives SORTOMIT as the jobname. 2. The EXEC statement identifies SYNCSORT as the program to be executed. The STOPAFT PARM instructs SyncSort to terminate after sorting 1,000 records. 3. The STEPLIB DD statement instructs the system to look for SyncSort in the library named SORT.RESI.DENCE. The DISP indicates that this library may be shared. 4. The SYSOUT DD statement assigns the SyncSort messages to the output device associated with SYSOUT class A. 5. The SORTIN DD statement gives INPUT as the input data set name, specifies a 3490 tape unit with the volume serial number 012345. The data set is already in existence. The DCB parameter shows an LRECL of 100 bytes, a fixed blocked RECFM, and a 32700-byte BLKSIZE. The LABEL parameter shows that INPUT is the first data set on the tape, and that it has a standard label.

4.18

SyncSort for z/OS 1.2 Programmers Guide

6. The SORTOUT DD statement gives OUTPUT as the output data set name, and specifies a 3490 tape unit with the volume serial number 543210. The data set is not in existence yet. The DCB parameter for SORTOUT specifies the same LRECL and RECFM as SORTIN. The BLKSIZE will be selected by System Determined BLKSIZE (SDB) if active or by SyncSort if SDB is not active. 7. The five SORTWKxx DD statements reserve space on direct access devices for intermediate storage. Twenty cylinders are allocated for each of the five SORTWKxx data sets. 8. The SYSIN DD * statement marks the beginning of the system input stream that includes the sort control statements. 9. The SORT control statement specifies that one control field will be sorted on. It begins on byte 1 of the record, is 8 bytes long, contains character data, and is to be sorted in ascending order. 10. The OMIT control statement eliminates any record with JOHN DOE in its first eight bytes (i.e., in the sort control key). JOHN DOE records are not sorted and are not included in the STOPAFT figure. The EXEC statements STOPAFT PARM terminates the sort after 1,000 (non-JOHN DOE) records have been put into the proper sequence. 11. The END control statement marks the end of the control statements. 12. The delimiter statement marks the end of the SYSIN input stream.

Chapter 4. JCL and Sample JCL/Control Statement Streams

4.19

Example 2

//SUMSORT // //STEPLIB //SYSOUT //SORTIN // // // // // //SORTOUT // // //SORTWK01 //SYSIN SORT SUM /*

PGM=SYNCSORT,PARM='EQUALS' DSN=SORT.RESI.DENCE,DISP=SHR SYSOUT=A DSN=FEB92,EMPLOYEE.MASTER, UNIT=3490,VOL=SER=135790, DISP=(OLD,KEEP) DD DSN=FEB92.EMPLOYEE.UPDATE, UNIT=3490,VOL=SER=999999, DISP=(OLD,KEEP) DD DSN=MAR92.EMPLOYEE.MASTER, UNIT=3490,VOL=SER=246809, DISP=(NEW,KEEP) DD UNIT=SYSDA,SPACE=(CYL,20) DD * FIELDS=(1,9,ZD,A,10,2,BI,A) FIELDS=(12,4,PD)

JOB EXEC DD DD DD

1 2 3 4 5

7 8 9 10 11

Figure 183. Sample JCL/Control Stream (2) 1. The JOB statement gives SUMSORT as the jobname. 2. The EXEC statement identifies SYNCSORT as the program to be executed. The EQUALS PARM interacts with the SUM control statement to preserve the first of a series of equal-keyed records. 3. The STEPLIB DD statement instructs the system to look for SyncSort in the library named SORT.RESI.DENCE. The DISP shows the library may be shared. 4. The SYSOUT DD statement assigns the SyncSort messages to the output device associated with class A. 5. The SORTIN DD statements define two concatenated data sets: FEB92.EMPLOYEE.MASTER and FEB92.EMPLOYEE.UPDATE. They are found on standard labeled 3490 tape units (volume serial numbers 135790 and 999999, respectively). These data sets are already in existence. 6. The SORTOUT DD statement gives MAR92.EMPLOYEE.MASTER as the output data set name and specifies a 3490 tape unit with the volume serial number 246809. The data set is not in existence yet.

4.20

SyncSort for z/OS 1.2 Programmers Guide

The DCB RECFM and LRECL parameters for SORTOUT default to that of the first SORTIN file. The BLKSIZE will be selected by System Determined BLKSIZE (SDB) if active or by SyncSort if SDB is not active. 7. The SORTWK01 DD statement reserves space on a direct access device for intermediate storage. Twenty cylinders are allocated. Intermediate storage must be provided whenever the SUM control statement is used with a sort. 8. The SYSIN DD statement marks the beginning of the system input stream that includes the sort control statements. 9. The SORT control statement specifies that two control fields will be sorted on. The major control field begins on byte 1 of the record, is 9 bytes long, contains zoned decimal data, and is to be sorted in ascending numerical order. The second, less significant, control field is found in the next two bytes of the record (bytes 10 and 11), is in (unsigned) binary format, and is to be sorted in ascending order. 10. Whenever two records have equal control fields, the sort will attempt to summarize them. If the result of summing the packed decimal data found in the 4-byte field beginning at byte 12 can be contained in four bytes, one of the two records will be retained, the sum stored in bytes 12-15, and the other record will be deleted. The EQUALS PARM guarantees that the first of the two records will be preserved; thus, if a record from the FEB92.EMPLOYEE.MASTER file has the same key as one from the FEB92.EMPLOYEE.UPDATE file, it is the master record which is retained in the output file, containing their sum. 11. The delimiter statement marks the end of the SYSIN input stream.

Chapter 4. JCL and Sample JCL/Control Statement Streams

4.21

Example 3

//SORTSKIP JOB // EXEC PGM=SYNCSORT //$ORTPARM DD * STOPAFT=100 //STEPLIB DD DSN=SORT.RESI.DENCE,DISP=SHR //SYSOUT DD SYSOUT=A //SORTIN DD DSN=EXPORT.SHIPPING.VOL6, // UNIT=TAPE,VOL=SER=112233, // DISP=(OLD,KEEP) //SORTOUT DD DSN=RECENT.MAJOR.EXPORTS, // UNIT=TAPE,VOL=SER=332211, // DISP=(NEW,KEEP) //SORTWK01 DD SPACE=(CYL,20),UNIT=SYSDA //SORTWK02 DD SPACE=(CYL,20),UNIT=SYSDA //SORTWK03 DD SPACE=(CYL,20),UNIT=SYSDA //SYSIN DD * SORT FIELDS=(19,5,CH,A), EQUALS,SKIPREC=1000 INCLUDE COND=(37,4,BI,GE,X'50') /* Figure 184. Sample JCL/Control Stream (3) 1. The JOB statement gives SORTSKIP as the jobname.

1 2 3 4 5 6

9 10 11 12

2. The EXEC statement identifies SYNCSORT as the program to be executed. 3. The $ORTPARM DD statement is used here to initiate a test run of the SORTSKIP job by supplying the STOPAFT PARM to SyncSort. It instructs SyncSort to terminate after sorting the first 100 of the records INCLUDE selects from the SKIPREC-edited input file. 4. The STEPLIB DD statement instructs the system to look for SyncSort in the library named SORT.RESI.DENCE. The DISP indicates that this library may be shared. 5. The SYSOUT DD statement assigns the SyncSort messages to the output device associated with SYSOUT class A. 6. The SORTIN DD statement gives EXPORT.SHIPPING.VOL6 as the input data set name. It is found on a standard labeled tape having the volume serial number 112233. This data set is already in existence. 7. The SORTOUT DD statement assigns the RECENT.MAJOR.EXPORTS data set name to the output file, and specifies a tape unit with the volume serial number 332211. This

4.22

SyncSort for z/OS 1.2 Programmers Guide

data set is not yet in existence. The DCB RECFM and LRECL parameters for SORTOUT default to those of the first SORTIN file. The BLKSIZE will be selected by System Determined BLKSIZE (SDB) if active or by SyncSort if SDB is not active. 8. The three SORTWKxx DD statements reserve space on direct access devices for intermediate storage. Twenty cylinders are allocated for each SORTWK data set. 9. The SYSIN DD statement marks the beginning of the system input stream that includes the sort control statements. 10. The SORT control statement specifies that one control field will be sorted on. It begins on byte 19 of the record, is 5 bytes long, contains character data, and is to be sorted according to ascending order. The EQUALS parameter preserves the SORTIN order of records with identical data in these five bytes. The SKIPREC parameter eliminates the first 1,000 records of the SORTIN file from consideration; these records are eliminated before the INCLUDE statement takes effect. 11. The INCLUDE statement compares the 4 bytes beginning with byte 37 of the record to the hexadecimal literal, which will be padded on the right with binary zeros to the indicated (4 byte) length. The record is eliminated from the sort unless the binary data in that field is at least as great as the padded constant. The INCLUDE/OMIT statement takes effect after SKIPREC but before STOPAFT. 12. The delimiter statement marks the end of the SYSIN input stream.

Chapter 4. JCL and Sample JCL/Control Statement Streams

4.23

A Merge without Exit Routines Example 4

//EDITMERG JOB //MERGE1 EXEC PGM=SYNCSORT //STEPLIB DD DSN=SORT.RESI.DENCE,DISP=SHR //SYSOUT DD SYSOUT=A //SORTIN08 DD DSN=SALES91,UNIT=TAPE, // VOL=SER=123456,DISP=(OLD,KEEP) //SORTIN12 DD DSN=SALES92,UNIT=TAPE, // VOL=SER=654321,DISP=(OLD,KEEP) //SORTIN03 DD DSN=SALES93,UNIT=3390, // VOL=SER=DISK11,DISP=SHR //SORTOUT DD DSN=SALES.PATTERN,UNIT=3390, // VOL=SER=DISK08,DISP=(NEW,KEEP), // SPACE=(CYL,5), // DCB=(LRECL=20,RECFM=VB, // BLKSIZE=27980) //SYSIN DD * MERGE FIELDS=(5,4,ZD,A) RECORD TYPE=V,LENGTH=(100,,20) INREC FIELDS=(1,8,29,6,12,6) /* Figure 185. Sample JCL/Control Stream (4) 1. The JOB statement gives EDITMERG as the jobname.

1 2 3 4 5

7 8 9 10 11

2. The EXEC statement identifies SYNCSORT as the program to be executed. 3. The STEPLIB DD statement instructs the system to look for SyncSort in the library named SORT.RESI.DENCE. The DISP shows the library may be shared. 4. The SYSOUT DD statement assigns the SyncSort messages to the output device associated with SYSOUT class A. 5. Three data sets are to be merged: SALES91, SALES92 and SALES93. SALES91 and SALES92 are found on standard labeled tapes with the volume serial numbers 123456 and 654321, respectively. The DD statement for SALES93 specifies a 3390 disk device with the volume serial number DISK11. These three data sets are already in existence, and the disk data set SALES93 may be shared. They are assigned distinct SORTINnn numbers, as required. 6. The SORTOUT DD statement assigns the name SALES.PATTERN to the output data set and specifies a 3390 disk device with the volume serial number DISK08. Five

4.24

SyncSort for z/OS 1.2 Programmers Guide

cylinders of primary space have been allocated on this volume. The data set does not yet exist. DCB parameters are provided, preventing them from defaulting to those of the SORTIN08 file. 7. The SYSIN DD statement marks the beginning of the system input stream that includes the sort control statements. 8. The MERGE control statement specifies one control field. It begins on byte 5 (the first data byte of the record since TYPE=V is specified on the RECORD statement) and is 4 bytes long. This field contains zoned decimal data and is to be merged in ascending order. 9. The RECORD statement indicates that variable-length records are being merged and indicates the record length at various processing stages. The maximum input record length is specified as 100 bytes. Since there is no E15, the post-E15 length value is not coded and so defaults to this figure. The INREC statement reduces this maximum record length to just 20 bytes. 10. According to the RECORD control statement, the input record may be 100 bytes long. The INREC statement reduces each record to the 20 bytes crucial to this application: the 4-byte RDW and 4-byte merge control field (i.e., the first 8 bytes of the record), the 6-byte field beginning at byte 29 (the 25th data byte) and the 6-byte field beginning at byte 12 (the 8th data byte). As required, the RDW remains in the first four bytes. The records to be merged are no more than 20 bytes long and contain three fields following the RDW. 11. The delimiter statement marks the end of the SYSIN input stream.

Chapter 4. JCL and Sample JCL/Control Statement Streams

4.25

A Copy without Exit Routines Example 5

//COPYNYC JOB //COPY1 EXEC PGM=SYNCSORT //STEPLIB DD DSN=SORT.RESI.DENCE,DISP=SHR //SYSOUT DD SYSOUT=A //SORTIN DD DSN=USA.OUTLETS,UNIT=TAPE, // VOL=SER=149200,DISP=(OLD,KEEP) //SORTOUT DD DSN=NYC.OUTLETS,UNIT=3390, // VOL=SER=DISK08,SPACE=(CYL,5), // DISP=(NEW,KEEP) //SYSIN DD * SORT FIELDS=COPY INCLUDE COND=(56,3,CH,EQ,C'NYC') /* Figure 186. Sample JCL/Control Stream (5) 1. The JOB statement gives COPYNYC as the jobname.

1 2 3 4 5 6

7 8 9 10

2. The EXEC statement identifies SYNCSORT as the program to be executed. 3. The STEPLIB DD statement instructs the system to look for SyncSort in the library named SORT.RESI.DENCE. The DISP shows the library may be shared. 4. The SYSOUT DD statement assigns the SyncSort messages to the output device associated with SYSOUT class A. 5. The SORTIN DD statement indicates the file to be copied. The data set name is USA.OUTLETS, and it is found on the standard labeled tape with the volume serial number 149200. The data set is already in existence. 6. The SORTOUT DD statement names the copied file NYC.OUTLETS, and specifies a 3390 disk device with the volume serial number of DISK08. Five cylinders of primary space have been allocated on this volume. The data set does not yet exist, but is to be kept whether or not the job terminates normally. The DCB RECFM and LRECL parameters for SORTOUT default to that of the first SORTIN file. The BLKSIZE will be selected by System Determined BLKSIZE (SDB) if active or by SyncSort if SDB is not active. 7. The SYSIN DD statement marks the beginning of the system input stream that includes the sort control statements.

4.26

SyncSort for z/OS 1.2 Programmers Guide

8. The FIELDS parameter specifies a copy application. This could have been coded as MERGE FIELDS=COPY without affecting program execution. 9. The INCLUDE control statement edits the USA.OUTLETS input file, eliminating all records which do not have the character string NYC in bytes 56-58. Only 'NYC' records will be copied. 10. The delimiter statement marks the end of the SYSIN input stream.

Chapter 4. JCL and Sample JCL/Control Statement Streams

4.27

A Sort with an Exit Routine Already Link-edited Example 6

//ONE#EXIT //STEP1 //STEPLIB //SYSOUT //MODLIB //SORTIN // //SORTOUT // // //SORTWK01 //SORTWK02 //SORTWK03 //SORTWK04 //SYSIN SORT RECORD MODS END /*

JOB EXEC DD DD DD DD

PGM=SYNCSORT,PARM='MSG=SC' DSN=SORT.RESI.DENCE,DISP=SHR SYSOUT=A DSN=EXIT.E15,DISP=SHR DSN=INPUT,UNIT=3390, VOL=SER=ABCDEF,DISP=(SHR) DD DSN=OUTPUT,UNIT=3390, VOL=SER=GHIJKL,SPACE=(CYL,10) DISP=(NEW,KEEP,DELETE) DD UNIT=SYSDA,SPACE=(CYL,20) DD UNIT=SYSDA,SPACE=(CYL,20) DD UNIT=SYSDA,SPACE=(CYL,15) DD UNIT=SYSDA,SPACE=(CYL,15) DD * FIELDS=(10,25,CH,A,40,10,ZD,D), FILSZ=9000 TYPE=V,LENGTH=(1024,,,44,192) E15=(E15,600,MODLIB,N)

1 2 3 4 5 6 7

9 10 11 12 13 14

Figure 187. Sample JCL/Control Stream (6) 1. The JOB statement gives ONE#EXIT as the jobname. 2. The EXEC statement identifies SYNCSORT as the program to be executed. The MSG PARM option requests that all messages be routed to the SYSOUT DD statement but only critical messages be routed to the console. 3. The STEPLIB DD statement instructs the system to look for SyncSort in the library named SORT.RESI.DENCE. The DISP shows the library may be shared. 4. The SYSOUT DD statement assigns the SyncSort messages to the output device associated with SYSOUT class A. 5. The MODLIB DD statement defines the library in which the exit routine resides; MODLIB is referenced in the MODS control statement. The data set name of the library is EXIT.E15, and the DISP shows that the library may be shared.

4.28

SyncSort for z/OS 1.2 Programmers Guide

6. The SORTIN DD statement gives INPUT as the input data set name and specifies a 3390 disk with the volume serial number ABCDEF. The DISP parameter indicates that the data set is already in existence and may be shared. 7. The SORTOUT DD statement gives OUTPUT as the output data set name and specifies a 3390 disk with the volume serial number GHIJKL. Ten cylinders of primary space have been allocated on this volume. The DISP parameter shows that this data set is not yet in existence. 8. The four SORTWK statements reserve space on four temporary data sets for intermediate storage. Twenty cylinders are to be reserved on the first two data sets, fifteen on the second two data sets. 9. The SYSIN DD statement marks the beginning of the input stream that includes the sort control statements. 10. The SORT control statement specifies two sort control fields. The first begins on byte 10 (data byte 6) of the record, is 25 bytes long, contains character data, and is to be sorted in ascending order. The second control field begins on byte 40 (data byte 36) of the record, is 10 bytes long, has zoned decimal data, and is to be sorted in descending order. FILSZ instructs SyncSort to terminate abnormally unless the post-E15 file contains exactly 9,000 records. 11. The RECORD control statement shows that variable-length records are being sorted. The first LENGTH value reports that the maximum length of records in the SORTIN data set is 1024 bytes. The comma coded for the second LENGTH value shows that this maximum length is not altered by the exit routine. The comma coded for the third LENGTH value shows that this maximum length is not affected by an E35 or the INREC/OUTREC statements. The fourth LENGTH value shows that the smallest record in the input data set is 44 bytes long. The fifth LENGTH value shows that the record length that occurs most frequently in SORTIN is 192 bytes. (This value will be used to determine segment size.) 12. The MODS control statement states that the exit-type is E15. The name of the actual exit routine included at this exit is also E15. The routine requires 600 bytes of memory and resides in a library defined on the MODLIB DD statement. Finally, the N indicates that link-editing of the routine has already been performed. 13. The END control statement marks the end of the control statements. 14. The delimiter statement marks the end of the SYSIN input stream.

Chapter 4. JCL and Sample JCL/Control Statement Streams

4.29

A Sort with an Exit Routine to be Link-edited Example 7

//LINKEXIT //STEP //SYSOUT //SORTIN // // // // //SORTOUT // // //SORTMODS //MODLIB //SYSLMOD // //SYSLIN // //SYSPRINT //SYSUT1 //SYSIN SORT RECORD MODS

JOB EXEC DD DD

SUM END . . . Object deck EXIT2 for E35 exit routine . . . /*

PGM=SYNCSORT SYSOUT=A DSN=IN.FILE.JANUARY, UNIT=TAPE,VOL=SER=135790, DISP=OLD,DELETE), DCB=(LRECL=200,RECFM=FB, BLKSIZE=4000),LABEL=(2,SL) DD DSN=OUT.FILE.FEBRUARY, UNIT=TAPE,VOL=SER=097863, DISP=(NEW,KEEP),LABEL=(1,SL) DD DSN=A.PART.DATA.SET,DISP=OLD DD DSN=EXIT.NO.ONE,DISP=SHR DD DSN=&&LINK,UNIT=SYSDA, SPACE=(CYL,(1,1,1)) DD DSN=&&TEMP,UNIT=SYSSQ, SPACE=(TRK,1) DD SYSOUT=A DD UNIT=SYSDA,SPACE=(CYL,(1,1)) DD * FIELDS=(20,30,CH,A), DYNALLOC=(SYSDA,6) TYPE=F,LENGTH=200 E15=(EXIT1,600,MODLIB,N), E35=(EXIT2,500,SYSIN) FIELDS=(1,10,ZD) TOTAL BALANCE ACCOUNTS FOR JANUARY BEGIN FEBRUARY

1 2 3 4

6 7 8 9 10 11 12 13 14 15 16 17

18

19 Figure 188. Sample JCL/Control Stream (7)

1. The JOB statement gives LINKEXIT as the jobname. 2. The EXEC statement identifies SYNCSORT as the program to be executed.

4.30

SyncSort for z/OS 1.2 Programmers Guide

3. The SYSOUT DD statement assigns the SyncSort messages to the output device associated with SYSOUT class A. 4. The SORTIN DD statement gives IN.FILE.JANUARY as the input data set name, and specifies a tape unit with the volume serial number 135790. The DISP parameter shows that the data set is already in existence. The DCB parameter shows an LRECL of 200 bytes, a fixed blocked RECFM, and a 4000-byte BLKSIZE. The LABEL parameter shows that IN.FILE.JANUARY is the second data set on the tape, and that it has a standard label. 5. The SORTOUT DD statement gives OUT.FILE.FEBRUARY as the output data set name, and specifies a tape unit with the volume serial number 097863. The DISP parameter shows that the data set is not in existence yet. The DCB RECFM and LRECL parameters for SORTOUT default to that of the first SORTIN file. The BLKSIZE will be selected by System Determined BLKSIZE (SDB) if active or by SyncSort if SDB is not active. The LABEL parameter shows that OUT.FILE.FEBRUARY is to be the first data set on the tape, and will have a standard label. 6. The SORTMODS DD statement defines the partitioned data set that will contain the exit routine object module that has not been link-edited and is being included in the SYSIN data stream. The DISP shows the data set may not be shared. 7. The MODLIB DD statement defines the partitioned data set in which the already linkedited exit routine resides. (Note MODLIB is referenced on the MODS control statement.) The data set name of the exit library is EXIT.NO.ONE. The DISP shows the data set may be shared. 8. The SYSLMOD DD statement defines a temporary data set called &&LINK that will contain the exit routine after it has been link-edited. A direct access device will be used with 1 cylinder reserved for primary space allocation, 1 cylinder for secondary space allocation, and 1 directory block. 9. The SYSLIN DD statement defines the temporary data set that will contain the linkage editor control statements that SyncSort will use when link-editing the exit. The name of this data set is &&TEMP. It is to be on any sequential-access device with 1 track reserved if the data set is allocated to disk. 10. The SYSPRINT DD statement defines the data set on which the linkage editor will write its messages. Whatever device is assigned to SYSOUT=A will be used. 11. The SYSUT1 DD statement defines the temporary data set that will be used as a work area by the linkage editor. It is to be on a direct access device with 1 cylinder of primary space allocated, and 1 cylinder of secondary space allocated.

Chapter 4. JCL and Sample JCL/Control Statement Streams

4.31

12. The SYSIN DD statement marks the beginning of the input stream that includes the sort control statements and also the object deck of the exit routine to be link-edited. 13. The SORT control statement shows that one control field will be sorted on. It begins on byte 20 of the record, is 30 bytes long, contains character data, and is to be sorted according to ascending order. The DYNALLOC parameter specifies that 6 direct access areas are to be reserved for sortwork data sets. 14. The RECORD control statement shows that fixed-length records are being sorted. The LENGTH parameter gives 200 bytes as the length of the records at input time, and, by not specifying values for l2 and l3, implicitly states that the length of these records will not be changed during the sort. 15. The MODS control statement shows that the first exit-type is E15. The name of the routine for this exit is EXIT1. It will take 600 bytes in main storage, resides in a library defined on the MODLIB DD statement, and has already been link-edited. The second exit-type is E35. The name of the routine for the exit is EXIT2, and it will take 500 bytes in main storage. The object deck for the routine is to be included in the SYSIN portion of the job stream, and, because of the absence of a letter in the last subparameter position for this group, the sort assumes that the routine requires link-editing and will be link-edited together with any other routines for this phase. 16. The SUM control statements FIELDS parameter identifies one summary field. It begins on byte 1 of the record, is 10 bytes long, and has zoned decimal data. The rest of the statement is a comment. 17. The END control statement marks the end of the control statements and also contains a comment. 18. The EXIT2 object deck to be link-edited is included after the END statement in the SYSIN stream. 19. The delimiter statement marks the end of the SYSIN input stream for the sort.

4.32

SyncSort for z/OS 1.2 Programmers Guide

Multiple Output Files Example 8

//MULTOUT // //STEPLIB //SYSOUT //SORTIN // //SORTOUT // // //SORTOFDS // // //SORTWK01 //SORTWK02 //SORTWK03 //SYSIN SORT OUTFIL OUTFIL /*

JOB EXEC DD DD DD

PGM=SYNCSORT DSN=SORT.RESI.DENCE,DISP=SHR SYSOUT=A DSN=SALES.RECORDS, VOL=SER=DISK1,DISP=SHR DD DSN=SORTED.SALES.RECORDS, UNIT=TAPE,VOL=SER=112233, DISP=(NEW,KEEP) DD DSN=DOMESTIC.SALES.RECORDS, VOL=SER=DISK8,DISP=(NEW,KEEP), SPACE=(CYL,40),UNIT=SYSDA DD SPACE=(CYL,20),UNIT=SYSDA DD SPACE=(CYL,20),UNIT=SYSDA DD SPACE=(CYL,20),UNIT=SYSDA DD * FIELDS=(10,12,BI,A) FILES=OUT,INCLUDE=ALL FILES=DS,OMIT=(62,3,CH,NE,C'USA')

1 2 3 4 5 6

9 10 11 12 13

Figure 189. Sample JCL/Control Stream (8) 1. The JOB statement gives MULTOUT as the jobname. 2. The EXEC statement identifies SYNCSORT as the program to be executed. 3. The STEPLIB DD statement instructs the system to look for SyncSort in the library named SORT.RESI.DENCE. The DISP parameter shows that the library may be shared. 4. The SYSOUT DD statement assigns the SyncSort messages to the output device associated with SYSOUT class A. 5. The SORTIN DD statement gives SALES.RECORDS as the input data set name, and specifies a disk with the volume serial DISK1. The DISP parameter indicates that the data set is already in existence and may be shared. 6. The SORTOUT DD statement names one of the output sorted files SORTED.SALES.RECORDS, and specifies a tape device with volume serial number 112233 for storage. The DISP parameter indicates that the data set does not yet exist, but it is to be kept whether or not the job terminates normally.

Chapter 4. JCL and Sample JCL/Control Statement Streams

4.33

7. The SORTOFDS DD statement names a second sorted output file DOMESTIC.SALES.RECORDS, and specifies a disk device with volume serial number DISK8 for storage. Forty cylinders of space have been allocated on this volume. The DISP parameter indicates that the data set does not yet exist, but is to be kept whether or not the job terminates normally. 8. The three SORTWK DD statements reserve space on direct access devices for intermediate storage. Twenty cylinders are allocated for each of the three SORTWK data sets. 9. The SYSIN DD statement marks the beginning of the input stream that includes the sort control statements. 10. The SORT control statement specifies that one control field will be sorted on. It begins on byte 10 of the record, is 12 bytes long, contains unsigned binary (BI) data and is to be sorted according to ascending order. 11. The first OUTFIL control statement is associated with the SORTOUT DD statement. The INCLUDE parameter specifies that all input records are to be included in this output file. 12. The second OUTFIL control statement is associated with the SORTOFDS DD statement. The OMIT parameter specifies that records which do not contain USA in bytes 62, 63 and 64 are not to be included in this file. 13. The delimiter statement marks the end of the SYSIN input stream.

4.34

SyncSort for z/OS 1.2 Programmers Guide

Chapter 5. PARM Options

PARM options can be specified to provide processing information and to override installation defaults for JCL-initiated and program-invoked applications. For a JCL-initiated application, specify the PARM option(s) on the EXEC statement as follows:

PARM='option,...' Figure 190. PARM Parameter Format For a program-invoked application, specify the PARM option(s) in a $ORTPARM DD data set. Omit the keyword PARM= and the single quotes. PARM options for a JCL-initiated application can also be specified in a $ORTPARM data set.

Additional MAXSORT PARMs


The MAXSORT feature, designed for large sorting applications, is initiated by the MAXSORT PARM. The following additional PARMs can be specified for a MAXSORT application: BKPTDSN, DYNATAPE, MAXWKSP, MINWKSP, NODYNATAPE, RESTART, SORTSIZE, SORTTIME, and TAPENAME. These PARMs are described in Chapter 9. MAXSORT.

Chapter 5. PARM Options

5.1

PARASORT PARM
The PARASORT feature, designed to reduce elapsed time for multi-volume and/or concatenated tape SORTIN sort applications, is initiated by the PARASORT PARM. For additional information on PARASORT, see Chapter 10. PARASORT.

DB2 Query Support PARM


DB2 Query Support, which allows DB2 data to be passed directly into a SORT or COPY operation without the use of setup steps or the need for user-written E15 exits, is initiated by the DB2 Query Support PARM. For additional information, see Chapter 11. SyncSort DB2 Query Support .

Additional Tape Sort PARMs


The following additional PARMs can be specified for a Tape Sort: OSCL, BALN and POLY. The CRCX and PEER PARMs are accepted but ignored. These PARMs are described in Chapter 12. Tape Sort.

Precedence Rules
There are three ways in which options can be specified, though not all options can be specified in all three ways: As an installation specification As a PARM specification As a SORT/MERGE control statement specification.

Note that there are six options that can be specified as a PARM option or a SORT/MERGE option. They are: CENTWIN, DYNALLOC, EQUALS/NOEQUALS, FILSZ, SKIPREC and STOPAFT. When an option is specified in more than one way, the following precedence rules apply: A SORT/MERGE or PARM specification overrides an installation specification. A PARM specification overrides a SORT/MERGE specification except for EQUALS/ NOEQUALS.

PARM Option Summary Chart


The chart on the following pages lists the PARM options. Underscored PARM options are delivered defaults which may have been altered at installation time.

5.2

SyncSort for z/OS 1.2 Programmers Guide

PARM Option Name BALANCE

Disk Sort, MAXSORT, and PARASORT Balances importance of CPU time, elapsed time, and I/O activity for best overall sort performance. See CPU, ELAP, and IO. Note that these options and BALANCE are all mutually exclusive. Produces WERnnB messages. Generates a sliding (s) or fixed (f) 100-year window that determines the century to which 2-digit year data belongs. Ensures that such data is processed correctly as a 4-digit year by SORT/MERGE and INCLUDE OMIT. Also enables OUTREC processing to output a 4-digit year (yyyy) from 2-digit year input (yy). CMP=CPD improves performance. No.

Available with Tape Sort?

BMSG CENTWIN= 0 /s /f

No. No.

CMP= CPD/CLC COMMAREA/ NOCOMMAREA CORE/SIZE=n

No. CMP=CLC (no data validation) is the standard.

Provides a communication area No between exit programs. Changes the amount of memory in which sort/merge can run. Minimizes CPU time at expense of other performance measures. See BALANCE, ELAP, and IO. Note that these options and CPU are all mutually exclusive. Provides a SyncSort SNAP dump in the event of a critical error. Provides diagnostic information for certain error conditions. Requests the dynamic allocation of work data sets. Indicates a COBOL exit. Yes.

CPU

No.

DEBUG

No.

DIAG

Plus additional diagnostic trace.

DYNALLOC E15/E35=COB

No. No.

Chapter 5. PARM Options

5.3

PARM Option Name ELAP

Disk Sort, MAXSORT, and PARASORT Minimizes elapsed time at expense of other performance measures. See BALANCE, CPU, and IO. Note that these options and ELAP are all mutually exclusive. EQUALS acts to preserve the order of equal-keyed records. It is not available with PARASORT. Enables special processing for applications with record counts that exceed SyncSorts default internal limit. Indicates the (actual or estimated) number of records after input processing (E14, E15, INCLUDE/OMIT, SKIPREC, STOPAFT, and Phase 1 SUM). FILSZ=n causes sort termination if n is incorrect. FLAG and MSG control the routing of output messages. Enables hiperbatch processing for SORTIN data set. Places SORTOUT data set into hiperbatch. Minimizes IO activity at expense of other performance measures. See BALANCE, CPU, and ELAP. Note that these options and IO are all mutually exclusive. Indicates how to handle I/O errors: user abend 999 with or without dump, or SyncSort error message only. No.

Available with Tape Sort?

EQUALS/ NOEQUALS

Yes.

EXTCOUNT

No.

FILSZ=n/En

FILSZ=En only. Does not take input processing (E14, E15) into account.

FLAG HBSI HBSO IO

Yes. No. No. No.

IOERR=ABE/ NOSNAP /NOIOERR

No. I/O errors generate user abend 999 plus dump.

L6=n,L7=n

Passes HISTOGRM data to No. optimize variable-length record sorts. LIST causes header line and control statements to be printed. Accepted but not processed. NOLIST is the standard for invoked sorts, LIST for JCL sorts.

LIST /NOLIST

5.4

SyncSort for z/OS 1.2 Programmers Guide

PARM Option Name

Disk Sort, MAXSORT, and PARASORT No. Yes. Yes. No.

Available with Tape Sort?

LOCALE= NONE /CURRENT Controls collating based on /name cultural environment. MSG MSGDD MSG and FLAG control the routing of messages. Changes the DD name of the message data set.

NULLOUT= RC0 /RC4 /RC16 Specifies the action to be taken when SORTOUT contains no records. OVFLO= RC0 /RC4 /RC16 Specifies the action to be taken if a summary field overflows or underflows during SUM processing. Specifies the action to be taken if the non-OUTFIL SORTOUT LRECL is larger than the SORTIN/SORTINnn LRECL. Changes the DCB of the message data set. RC16=ABE changes return code 16 to user abend 16. Overrides the RLSE operand in the SPACE parameter of the SORTWK DD statement(s). Specifies the amount of memory reserved for the user below the 16-megabyte line. Specifies the amount of memory reserved for the user above the 16-megabyte line. Affects VSAM SORTOUT only. Determines whether excess space is released. Specifies whether system-determined blocksize should be used to select an optimum blocksize for data sets when none is provided.

No.

PAD= RC0 /RC4 /RC16

No.

PRINT121

No. The standard is: DCB= (LRECL=120,BLKSIZE=120, RECFM=U). No. User abend 16 is the standard. No.

RC16=ABE/NORC16 RELEASE= ON /OFF

RESERVE=n/nK

No.

RESERVEX=n/nK

No.

RESET/ NORESET RLSOUT/ NORLSOUT SDB= ON/ OFF/ YES/ NO/ DISKONLY/ TAPEONLY/ LARGE/ SMALL/ INPUT/ LARGEONLY/ INPUTONLY

No. (Tape Sort does not accept VSAM output.) No. Excess SORTOUT space is not released. No.

Chapter 5. PARM Options

5.5

PARM Option Name SKIPREC=n

Disk Sort, MAXSORT, and PARASORT Indicates that n records should be skipped before the input file is sorted or copied. SKIPREC is not available for PARASORT. Sorts or copies at most n records that survive input file editing (E15, INCLUDE/OMIT, SKIPREC etc.) STOPAFT is not available for PARASORT. Specifies the action to be taken if the non-OUTFIL SORTOUT LRECL is smaller than the SORTIN/SORTINnn LRECL. Indicates if an uninitialized SORTIN or SORTINnn input file should be processed. Indicates the type of validity testing to be done when processing variable-length records. Indicates action to be taken when a variable-length record does not contain all fields referenced by INCLUDE or OMIT processing. Specifies the processing of empty VSAM data sets provided as input to a sort, merge, or copy. Specifies whether positive summarized ZD fields will be converted to a printable format. No.

Available with Tape Sort?

STOPAFT=n

No.

TRUNC= RC0 /RC4 /RC16

No.

UNINTDS=YES/ NO

No.

VLTEST=(n/ 1 , ON /OFF / OFF4)

No.

VLTESTI=n/ 0

No.

VSAMEMT= NO /YES

No.

ZDPRINT/ NZDPRINT

No.

SyncSort PARM Options


BALANCE
BALANCE BALANCE optimizes overall performance by balancing among CPU time, sort elapsed time, and I/O activity to SORTIN, SORTOUT and SORTWK. If you wish to emphasize one

5.6

SyncSort for z/OS 1.2 Programmers Guide

performance measure at the possible expense of others, use CPU, ELAP, or IO. See CPU, ELAP, and IO, below. Note that these options and BALANCE are all mutually exclusive. Cannot be used with Tape Sort.

BMSG
BMSG BMSG enables class B messages. They will appear wherever the MSG PARM option indicates informational messages are to be routed. Cannot be used with Tape Sort.

CENTWIN
0 CENTWIN = s f CENTWIN defines a sliding or fixed 100-year window that determines the century to which 2-digit year data belongs when processed by SORT, MERGE, INREC, OUTREC or OUTFIL OUTREC control statements. The 2-digit year data formats (Y2B, Y2C, Y2D, Y2P, Y2S and Y2Z) plus the full-date formats (Y2T, Y2U, Y2V, Y2W, Y2X, and Y2Y) work with CENTWIN to treat a 2-digit year value as a 4-digit year. The 2-digit and full-date year data formats can be specified on control statements as follows: Use SORT/MERGE control statements to correctly collate 2-digit years that span century boundaries. For information on using the 2-digit and full-date data formats for SORT/MERGE field specifications, see CENTWIN Parameter (Optional) on page 2.51 or on page 2.149. Use INCLUDE/OMIT or OUTFIL INCLUDE/OMIT control statements for correct comparisons involving 2-digit year and full-date data formats. For information on using the 2-digit year data formats for INCLUDE/OMIT processing, see Specifying Field-toField Standard Comparisons for Date Fields under the heading INCLUDE/OMIT Control Statement on page 2.19. For more information on specifying full-date formats, see pages 2.27-2.32. Use INREC/OUTREC or OUTFIL OUTREC control statements to convert 2-digit year and full-date data to 4-digit printable output. For information on using the 2-digit year data formats for OUTREC processing, see Converting Year Data with Century Window Processing on INREC, OUTREC, or OUTFIL OUTREC on page 2.112 and

Chapter 5. PARM Options

5.7

Example 5 on page 2.132. For more information on converting full-date formats, see the descriptions of the fi and fy2f,(c) parameters on pages 2.103-2.106, Table 11 on page 2.56, and Table 15 on page 2.107. In addition, two date formats, Y2ID and Y2IP, are provided for year conversion with INREC/OUTREC and OUTFIL OUTREC. These formats work with CENTWIN to expand a 2-digit year in packed decimal format to a 4-digit year while maintaining the packed decimal format in the output field. CENTWIN ensures that year data spanning centuries will be sequenced correctly. For example, without CENTWIN processing, an ascending sort/merge would sequence the year 01 before the year 98. With CENTWIN processing, the 01 field could be recognized as a twenty-first century date (2001) and would thus be sequenced after 98 (1998) for an ascending sort. The CENTWIN option generates either a sliding or fixed century window, depending on which form of CENTWIN is used: CENTWIN=s or CENTWIN=f. CENTWIN=s specifies a sliding century window, which automatically advances as the current year changes. The variable s is a number 0 through 100. This value is subtracted from the current year to set a century-window starting point. For example, in 1996 CENTWIN=20 would create the century window 1976 through 2075. Ten years later in 2006, the century starting year would slide to 1986 (2006 minus 20 = 1986) and the century window would be 1986 through 2085. The CENTWIN delivered default is s=0, which means the current year is the starting year of a century window. CENTWIN=f specifies a fixed century window. The variable f is a 4-digit year (yyyy) between 1000 and 3000. For example, CENTWIN=1976 establishes a fixed starting year 1976 for the century window 1976 through 2075. This window will not change as the current year changes. The century window defined by CENTWIN controls processing of year-data. If a 2-digit year field (indicated by Y2B, Y2C, Y2D, Y2P, Y2S, Y2Z, Y2ID, Y2IP, Y2T, Y2U, Y2V, Y2W, Y2X, or Y2Y) has a value less than the last two digits of the century window start year, the year field will be treated as a year in the century following the year of the century window, except for 00, which is considered to be in the same century as the century window start year. All other 2-digit years will be treated as in the same century as the century window start year. For example, consider the century window 1950 through 2049. The 2-digit year fields would be processed as follows:

5.8

SyncSort for z/OS 1.2 Programmers Guide

Two-digit Field 00 01 49 50 99

Processed as Year 2000 2001 2049 1950 1999

An ascending sort of the above sample data would produce output data in the following sequence: Two-digit Field 50 99 00 01 49 Processed as Year 1950 1999 2000 2001 2049

If CENTWIN has been specified on the SORT or MERGE control statement as well as in the PARM field, the PARM specification has precedence. Cannot be used with Tape Sort.

CMP
CPD CMP = CLC

CMP specifies the kind of compare operation to be used for sort/merge control fields up to 16 bytes long, bearing the format code PD or ZD. When CMP=CPD is used, ZD fields are PACKed and then compared. Invalid PD data may cause a system 0C7 abend and program termination. The integrity of fields labelled ZD is only guaranteed when they contain valid ZD data. Since the zone bits (the leftmost four bits of each byte) are lost during packing, UNPKing the field later restores only valid ZD data to its original state. Leading blanks are transformed to leading zeros and alphabetic character data that packs to a valid PD field is converted to valid ZD data. CMP=CLC uses the compare logical instruction for all PD and ZD control fields. No data validation is done and the integrity of the output is maintained.

Chapter 5. PARM Options

5.9

CMP=CPD is the delivered default for the PARM. The delivered default for VLTEST is 1, and is consistent with this default. Changing the VLTEST default from 1 to any even number forces the use of CMP=CLC when sorting variable-length records. For more detailed information and sample comparisons, see the section Comparing PD and ZD Control Fields on page 2.50. Cannot be used with Tape Sort.

COMMAREA
COMMAREA(n,x) COMMAREA(n) COMMAREA(,x) COMMAREA NOCOMMAREA

COMMAREA instructs SyncSort to provide an area for communication between exit programs. The size of this area is given as a decimal number n of bytes; x, a character string at most n bytes long, designates the initial value to be stored in this area. Regardless of the value of n, which may be between 1 and 256, x may not exceed 89 bytes in length. (Whenever x has fewer than n characters, it will be right-padded with blanks to a length of n.) If COMMAREA is specified via the EXEC statement, blanks may be included within the string x. However, if COMMAREA is specified via the $ORTPARM DD statement, intervening blanks are not allowed. In neither case is a right parenthesis permitted since it delimits the COMMAREA parameter. Both n and x are optional. If either subparameter is specified, it will determine the other: n defaults to the length of x, x defaults to n blanks. If neither x nor n is specified, n defaults to 80 bytes, x to 80 blanks. NOCOMMAREA is the program default: no area for communication between exit programs is provided, although exit routines may still use the 19th word of the save area. Exit program access to this communication area is described in the discussion of exit programs, see The Exit Communication Area on page 7.4. Cannot be used with Tape Sort.

5.10

SyncSort for z/OS 1.2 Programmers Guide

PARM Code

Communication Area DEBUG..... ......... ......... DEBUG DEBUG.... (5 blanks) (10 blanks) (80 blanks) (75 BLANKS)

COMMAREA(10,DEBUG) COMMAREA(10) COMMAREA COMMAREA(,DEBUG) COMMAREA(80,DEBUG)

Figure 191. Examples: Coding the COMMAREA PARM

CORE

n nK nM CORE = MAX SIZE MAX-n MAX-nK MAX-nM

CORE is used to override the installation default for the amount of memory the sort/merge is allowed to use. To specify an amount of memory, choose one entry from each pair of braces. Note that CORE and SIZE are synonymous. Note also that memory specification may be a decimal number of bytes (CORE=n), a decimal multiple of K, where K=1024 bytes (CORE=nK), or a decimal multiple of M, where M=1048576 bytes (CORE=nM). For simplicity, the following describes only CORE, specified in units of nK. CORE=nK Defines a maximum memory limit of nK below the 16-megabyte line. Assigns to the sort/merge all the available memory above and below the 16-megabyte line. Assigns to the sort/merge all the available memory above and below the 16-megabyte line less nK bytes, which is reserved below the 16-megabtye line.

CORE=MAX

CORE=MAX-nK

Consult your systems staff for any installation-specific modifications to the handling of CORE. For example, "CORE" will be limited if a maximum memory size for SyncSort was set at installation time.

Chapter 5. PARM Options

5.11

CPU
CPU CPU minimizes the CPU time of each sort at the expense of sort elapsed time and I/O activity. See BALANCE, ELAP and IO. Note that these options and CPU are all mutually exclusive. Cannot be used with Tape Sort.

DEBUG
DEBUG DEBUG produces a SyncSort SNAP dump in the event that a critical error forces the sort to terminate. A SNAP dump produced in this way is of use to a SyncSort analyst in debugging complex problems. See What to Do Before Calling SyncSort for z/OS Product Services on page 16.77. Note that the PSW AT ENTRY TO SNAP and general registers are useless for debugging. Cannot be used with Tape Sort.

DIAG
DIAG DIAG turns on both the IOERR=ABE and the RC16=ABE options (see these options for explanations). When specified for a Tape Sort, DIAG also turns on a diagnostic trace and causes system ABEND 0C1 in the event of an I/O error.

DYNALLOC

DYNALLOC

d = (d, n ,RETRY = OFF

(nn,mm) OFF [,SC=s])

DYNALLOC requests the dynamic allocation of SORTWK data sets on device type d. Specify the device type either as a decimal number (e.g., 3380) or by the system generic name (e.g., SYSDA). Any disk device accepted for a SORTWK DD statement can be

5.12

SyncSort for z/OS 1.2 Programmers Guide

specified. Note that if VIO is specified it will be ignored, and the installation default for the DYNALLOC device type will be used in its place. Note that the DYNALLOC parameter may be used alone, without any subparameters. In this case, the DYNALLOC installation default settings are used. For non-MAXSORT applications, n can be 1 through 255. The value n specifies the number of SORTWK data sets that can potentially be allocated. For values of n that are 31 or less, SyncSort can automatically raise the number to 32 if the application requires. When n is 33 through 255, this value specifies the maximum number of SORTWK data sets that can be allocated. For MAXSORT applications, n is the number of SORTWK data sets that will be allocated. As many as 32 SORTWK data sets can be specified for MAXSORT applications. The delivered default for n is 3. DYNALLOC=OFF can be specified to override a DYNALLOC=ON installation default. SORTWK data sets allocated by the DYNALLOC parameter normally supplement any SORTWK data sets allocated by SORTWKnn DD statements; however, note that there is an installation option to disable DYNALLOC if SORTWKnn DD statements are present. SyncSort uses the value specified in the RETRY parameter to request automatic DYNALLOC retry. This facility attempts to avoid a sortwork capacity exceeded condition when disk space is not immediately available to satisfy a DYNALLOC request. When RETRY is specified, SyncSort will automatically retry a specified number of times and wait a prescribed interval between DYNALLOC requests. The nn in the first position designates the number of times SyncSort will retry a failed DYNALLOC request. The minimum allowed is 1 and the maximum is 16. The mm in the second position designates the number of minutes SyncSort waits between each DYNALLOC request. The minimum allowed is 1 and the maximum is 15. RETRY=OFF can be specified to override a RETRY=ON installation default. In an environment where DFSMS manages temporary work data sets, the SC subparameter specifies a storage class s for SyncSort to use when dynamically allocating SORTWORK data sets. The storage administrator at your installation defines the names of the storage classes you can specify. Note that an installation written automatic class selection (ACS) routine can override the storage class you specify. If SMS is not installed or active to manage temporary work data sets, the d device specification will be used in the SORTWORK dynalloc request. If DYNALLOC has been specified on the SORT control statement as well as in the PARM field, the PARM specification will take precedence. Cannot be used with Tape Sort.

Chapter 5. PARM Options

5.13

E15
E15=COB E15 specifies the E15=COB option in order to include an E15 exit written in COBOL without coding C on the MODS control statement. Cannot be used with Tape Sort.

E35
E35=COB E35 specifies the E35=COB option in order to include an E35 exit written in COBOL without coding C on the MODS control statement. Cannot be used with Tape Sort.

ELAP
ELAP ELAP minimizes the elapsed time (wall clock time) of each sort at the expense of CPU time and I/O activity. See BALANCE, CPU and IO. Note that these options and ELAP are all mutually exclusive. Cannot be used with Tape Sort.

EQUALS
EQUALS NOEQUALS EQUALS guarantees that the first of a series of equal-keyed records is either first-in (SORT) or from the lowest numbered SORTINnn data set (MERGE). With NOEQUALS, there is a random element to the order in which records with identical control fields will appear in the output. With or without EQUALS, MERGE preserves the order of equalkeyed records within any one data set. When used in conjunction with SUM, EQUALS indicates which of the equal-keyed records will be preserved, containing the sum: the record occurring first in SORTIN (for a sort), or

5.14

SyncSort for z/OS 1.2 Programmers Guide

drawn from the SORTINnn data set with the lowest nn number (for a merge) will contain the totaled fields. The EQUALS option can also be specified on the SORT/MERGE control statement. The specification on the control statement takes precedence over the specification in the PARM field.

EXTCOUNT
EXTCOUNT EXTCOUNT enables special processing to accommodate applications that have record counts that exceed SyncSorts default internal limit. By default, the internal limit on the number of records that can be sorted for variablelength data or for a sort application that uses the EQUALS option is 4,294,967,295 records. Specifying EXTCOUNT increases the internal limit to 140,737,488,355,327 records. Fixedlength sorts without EQUALS, and all merges and copies, have automatic support for the maximum number of records allowed by the EXTCOUNT parameter. Note that additional SORTWK space may be required when specifying the EXTCOUNT parameter with a VL sort or a fixed-length sort with EQUALS. The additional SORTWK space is 2 bytes per record. This amount can add a significant percentage to the SORTWK space needs if the LRECL of the records is small. (Small LRECLs are typical of files with an extremely large number of records). Therefore, when using EXTCOUNT with a VL sort or a fixed-length sort with EQUALS, insure that the extra SORTWK space will be available. Performance will usually be improved if the EXTCOUNT option is not in effect. Therefore, EXTCOUNT should be used only when appropriate to the application. If the record limit is exceeded, SyncSort will issue a critical error message and terminate the application. Cannot be used with Tape Sort.

FILSZ
n FILSZ = En FILSZ indicates the actual (FILSZ=n) or estimated (FILSZ=En) decimal number of records to be sorted, taking into account all record additions and deletions due to an E14 or E15

Chapter 5. PARM Options

5.15

exit routine, the INCLUDE/OMIT control statement, the SUM control statement and the SKIPREC and STOPAFT parameters. FILSZ=n instructs SyncSort to terminate with an error message unless exactly n records are to be sorted. Since the number of records SUMed in Phase 1 is indeterminate and may not be reproducible, much less predictable, only the estimated En value should be used if a SUM control statement is present. If FILSZ is specified for a Tape Sort, only the estimated En value may be given. It should indicate the number of records in the input file - not taking into account any records to be added or deleted by an E14 or E15 exit program. The FILSZ option can also be specified on the SORT control statement. The specification in the PARM field will take precedence over that on the control statement.

FLAG

FLAG(I) FLAG(U) NOFLAG

FLAG controls the routing of output messages. The MSG option, which handles messages more comprehensively, is explained later in this section. The format of the FLAG option is given below. Specify FLAG(I) to route all messages to the data set specified by the SYSOUT DD statement and only critical messages to the console. (This is the same as the MSG=SC PARM.) Specify FLAG(U) to route critical messages only to both the data set specified by the SYSOUT DD statement and the console. (This is the same as the MSG=CB PARM.) Specify NOFLAG to route critical messages only to the console, no messages to the data set specified by the SYSOUT DD statement. (This is the same as the MSG=CC PARM.)

HBSI
HBSI HBSI turns on hiperbatch processing for SORTIN data sets. To benefit from hiperbatch processing, the SORTIN data set should already reside in hiperbatch. Although hiperbatch does provide significant improvements in elapsed time, it causes some degree of degradation in other system resources. If you use HBSI and the SORTIN data set does not reside in

5.16

SyncSort for z/OS 1.2 Programmers Guide

hiperbatch, you may experience some system degradation while not realizing any of the benefits that accompany hiperbatch processing. Cannot be used with Tape Sort.

HBSO
HBSO HBSO turns on hiperbatch processing for SORTOUT data sets. HBSO benefits only subsequent job steps that utilize hiperbatch to access this data set. Cannot be used with Tape Sort.

IO
IO IO minimizes the I/O activity of each sort at the expense of sort elapsed time and CPU time. See BALANCE, CPU and ELAP. Note that these options and IO are all mutually exclusive. Cannot be used with Tape Sort.

IOERR
IOERR=ABE NOIOERR IOERR=NOSNAP IOERR specifies IOERR=ABE to receive user abend 999 if an I/O error should occur. This abend will cause the job step to terminate, producing a diagnostic dump. NOIOERR is the program default. If this option is in effect, SyncSort will, in the event of an I/O error, terminate with either a return code of 16 or a user abend 16, depending on the RC16 option that is used. Specify IOERR=NOSNAP to receive a user abend 999 if an I/O error should occur. This abend will cause the step to terminate, but no diagnostic dump will be produced, unless the DEBUG option is in effect. Cannot be used with Tape Sort.

Chapter 5. PARM Options

5.17

L6
L6=n L6 indicates the average number of bytes of work space each record will need, overriding (if present) the l6 parameter of the RECORD control statement. The decimal value n of the optional L6 parameter is provided by the HISTOGRM utility program. If neither L6 nor l6 is provided, SyncSort will estimate this value. L6 is only used for sorting variable-length records. It is ignored by Tape Sort, merge, and copy applications. Cannot be used with Tape Sort.

L7
L7=n L7 indicates the segment length that SyncSort should use for maximum sorting efficiency. The decimal value n of the optional L7 parameter is provided by the HISTOGRM utility program. (A segment is a fixed-length area used to contain all or part of a variable-length record.) The L7 value overrides (if present) the l7 parameter of the RECORD control statement. If neither L7 nor l7 is provided, SyncSort will estimate this value. L7 is only used for sorting variable-length records. It is ignored by Tape Sort, merge, and copy applications. Cannot be used with Tape Sort.

LIST
LIST NOLIST LIST, the default for the sort/merge program, causes header lines and control statements to be listed with the SYSOUT data set (in all likelihood, at the printer) for both JCL- and program-initiated executions. If NOLIST is specified, the control statements and header lines will not appear with this data set. Tape Sort accepts but does not process this parameter.

5.18

SyncSort for z/OS 1.2 Programmers Guide

LOCALE
NONE LOCALE = CURRENT name LOCALE controls cultural environment processing, allowing you to choose an alternative set of collating rules based on a specified national language. For SORT/MERGE processing, the alternative collating applies to character (CH) fields. For INCLUDE/OMIT comparison processing, the alternative collating applies to character fields and hexadecimal constants compared to character fields. SyncSort employs the callable services of IBMs Language Environment for z/OS to collate data in a way that conforms to the language and conventions of a selected locale. A locale defines single and multi-character collating rules for a cultural environment. Numerous predefined locales are available. NONE, the default setting for LOCALE, results in normal EBCDIC collating. CURRENT directs SyncSort to use the locale active when SyncSort begins. name is the name of a supplied or user-defined locale that is to be active during SyncSort processing. A locale name may be up to 32 characters and is not case sensitive. The locale active just before SyncSort processing begins will be restored when SyncSort processing completes. The following is a list of locales provided with the IBM National Language Resources Feature of LE/370.

Chapter 5. PARM Options

5.19

Locale Name C DA_DK DE_CH DE_DE EL_GR EN_GB EN_JP EN_US ES_ES FI_FI FR_BE FR_CA FR_CH FR_FR IS_IS IT_IT JA_JP NL_BE NL_NL NO_NO PT_PT SV_SE TR_TR

Language

Country

Danish German German Greek English English English Spanish Finnish French French French French Icelandic Italian Japanese Dutch Dutch Norwegian Portuguese Swedish Turkish Table 27.

Denmark Switzerland Germany Greece United Kingdom Japan United States Spain Finland Belgium Canada Switzerland France Iceland Italy Japan Belgium Netherlands Norway Portugal Sweden Turkey Defined Locales

Notes: 1. Make sure the JCL gives SyncSort access to the library that contains the loadable locale routines. For the supplied locales, these are the dynamically loadable routines in

5.20

SyncSort for z/OS 1.2 Programmers Guide

the IBM AD/Cycle LE/370 library. For more information, see the IBM publication Language Environment for z/OS & VM Installation and Customization Guide, SC264817. 2. If locale processing is used for fields specified in a SORT or MERGE control statement, VLTEST=1 will be forced on in addition to any other VLTEST options in effect. VLTEST=1 will cause SyncSort to terminate if a variable-length input record does not contain all SORT/MERGE control fields. 3. Although locale processing can improve performance compared to external collating routines, it should be used only when necessary. Locale processing can significantly degrade SORT/MERGE and INCLUDE/OMIT performance compared to normal collating. 4. An E61 exit cannot be used with locale processing. 5. Locale processing requires additional main storage to support the use of the IBM Language Environment facilities. For those jobs that use locale, the below-the-line region size should be increased by 1000K to accommodate the storage needs of the Language Environment modules. 6. LOCALE cannot be used with Tape Sort.

MSG
AB AC AP CB CC MSG = CP NO PC SC SP

MSG indicates where SyncSort messages are to be routed. The MSG codes assume that the printer is specified for the message data set; if a device other than the printer is specified for this data set, messages described as routed to the printer will be routed to this other device instead. AB AC causes all messages to be routed both to the printer and to the console. causes all messages to be routed to the console, none to the printer.

Chapter 5. PARM Options

5.21

AP

causes all messages to be routed to the printer, none to the console. This is the program default. causes only critical messages to be routed to the printer and to the console. (This is the same as the FLAG(U) option.) causes only critical messages to be routed to the console, no messages to the printer. (This is the same as the NOFLAG option.) causes only critical messages to be routed to the printer, no messages to the console. causes no messages to be routed to either the printer or the console. causes all messages to be routed to the printer and to the console. causes only critical messages to be routed to the console, all messages to the printer. (This is the same as the FLAG(I) option.) causes only critical messages to be routed to the printer, all messages to the console.

CB

CC

CP NO PC SC

SP

MSGDD
SYSOUT MSGDD = xxxxxxxx The program default for the DD name of the message data set is SYSOUT. To assign a different DD name, substitute any valid DD name for xxxxxxxx.

NULLOUT
RC0 NULLOUT = RC4 RC16

NULLOUT specifies the action to be taken when SORTOUT in a sort, merge, or copy application contains no data records. RC0 The delivered default instructs SyncSort to issue a return code of 0 if not overridden by a higher return code set for another reason. Instructs SyncSort to issue a WER461I warning message and continue processing. A return code of 4 will be issued if not overridden by a higher return code set for another reason.

RC4

5.22

SyncSort for z/OS 1.2 Programmers Guide

RC16 Instructs SyncSort to issue a WER461A message and terminate processing with a return code of 16. NULLOUT will be ignored for a BetterGener application. Cannot be used with Tape Sort.

OVFLO
RC0 OVFLO = RC4 RC16 OVFLO specifies the action to be taken if a summary field overflows or underflows during SUM processing. RC0 The delivered default instructs SyncSort to issue a WER049I warning message and continue processing. A return code of 0 will be returned if not overridden by a higher return code set for another reason. The WER049I will only be issued on the first occurrence of the overflow or underflow. Instructs SyncSort to issue a WER049I warning message and continue processing. A return code of 4 will be issued if not overridden by a higher return code set for another reason. The WER049I will only be issued on the first occurrence of the overflow or underflow.

RC4

RC16 Instructs SyncSort to issue a WER049A message and terminate processing with a return code of 16. Cannot be used with Tape Sort.

PAD
RC0 PAD = RC4 RC16 PAD specifies the action to be taken if the LRECL defined in the JCL for a non-OUTFIL SORTOUT is larger than the SORTIN/SORTINnn LRECL or the internally processed record length when the SORTIN/SORTINnn LRECL is modified by features. RC0 The delivered default instructs SyncSort to issue a WER462I message, pad fixedlength output records with binary zeros, and issue a return code of zero.

Chapter 5. PARM Options

5.23

RC4

Instructs SyncSort to issue a WER462I message and pad fixed-length output records with binary zeros. A return code of 4 will be issued if not overridden by a higher return code set for another reason.

RC16 Instructs SyncSort to issue a WER462A message and terminate processing with a return code of 16. Note that for a BetterGener application PAD will be ignored. The installation parameter SOPADGN will control processing for these applications. PAD will be ignored in applications in which the SORTIN/SORTINnn or SORTOUT is a VSAM data set. Cannot be used with Tape Sort.

PRINT121
PRINT121 PRINT121 changes SyncSorts DCB default for the message data set to the following: DCB=(LRECL=121,BLKSIZE=121,RECFM=FA) This PARM is useful when the application includes a COBOL exit which uses DISPLAY, EXHIBIT, or TRACE instructions. (These macros will otherwise cause conflicts between program and sort/merge messages.) An alternative is provided by the MSGDD parameter, used to change the name of the SyncSort message data set. The SyncSort program default for the message files DCB is: DCB=(LRECL=125,BLKSIZE=882,RECFM=VBA) PRINT121 is automatically implemented for all program-initiated sort/merges. Cannot be used with Tape Sort.

RC16
RC16=ABE NORC16 RC16=ABE will cause the sort to issue user ABEND 16 instead of return code 16. The sort step is abnormally terminated without a dump and subsequent job steps are generally flushed by the operating system. However, JCL may specify job step(s) to be executed only in the event of an ABEND.

5.24

SyncSort for z/OS 1.2 Programmers Guide

The delivered default is NORC16; unsuccessful completion of the sort causes a return code of 16 to be passed to the operating system or the invoking program. Cannot be used with Tape Sort.

RELEASE
ON RELEASE = OFF RELEASE=ON (the program default) turns on the RLSE operand in the SPACE parameter of the SORTWK DD statements. This will cause unused space to be released from sortwork units during execution time. Specify RELEASE=OFF to instruct SyncSort to turn off the RLSE operand in the SPACE parameter of the SORTWK DD statement. In this case, SyncSort will not release unused space from the sortwork units during sort execution. The RELEASE parameter has no effect on program-invoked sorts. Cannot be used with Tape Sort.

RESERVE
n RESERVE = nK nM RESERVE sets aside a specified amount of memory below the 16-megabyte line for the user. This parameter takes effect only when CORE=MAX is in effect. The memory may be specified as a decimal number of bytes (RESERVE=n), a decimal multiple of K, where K=1024 bytes (RESERVE=nK), or a decimal multiple of M, where M=1048576 bytes (RESERVE=nM). Cannot be used with Tape Sort.

RESERVEX
n RESERVEX = nK nM

Chapter 5. PARM Options

5.25

RESERVEX overrides the installation value that reserves a specified amount of memory above the 16-megabyte line for the user. This parameter takes effect only when CORE=MAX is in effect. The memory may be specified as a decimal number of bytes (RESERVEX=n), a decimal multiple of K, where K=1024 bytes (RESERVEX=nK), or a decimal multiple of M, where M=1048576 bytes (RESERVEX=nM). Cannot be used with Tape Sort.

RESET
RESET NORESET RESET will prevent VSAM from treating output data sets as MOD data sets, if an output VSAM file was created using the REUSE option. Cannot be used with Tape Sort.

RLSOUT
RLSOUT NORLSOUT RLSOUT releases all excess primary and secondary space from each output DASD file when the parm is specified and DISP=NEW is specified on output data set statements. NORLSOUT is the program default. In this case, SyncSort does not release any excess space on these output files. Cannot be used with Tape Sort.

5.26

SyncSort for z/OS 1.2 Programmers Guide

SDB
ON OFF YES NO DISKONLY SDB = TAPEONLY LARGE SMALL INPUT LARGEONLY INPUTONLY SDB specifies whether system-determined blocksize should be used to select an optimal blocksize for output data sets when none is provided. This parameter will automatically provide a blocksize that will most efficiently utilize the space on the output device. SDB=ON or YES enables the use of system-determined blocksize for both tape and new or previously allocated but unopened DASD output data sets except in the following conditions: A blocksize is found in the JCL DCB BLKSIZE specification or, in the case of a DISP=MOD tape data set, it is derived from an available tape label. The output file is a VSAM data set.

If the output data set is on DASD, the blocksize selected will be based upon the RECFM and LRECL, either specifically provided or determined from the usual analysis of SORTIN or RECORD statement attributes. For example, the blocksize selected for a blocked output data set assigned to a 3380 or 3390 DASD device will represent a size as close to half-track blocking as possible. If the output file is a tape data set, the blocksize will be determined from the RECFM and LRECL in conjunction with the following rules: RECFM of F or FS: BLKSIZE=LRECL RECFM of FB or FBS and LABEL type is not AL: BLKSIZE=highest multiple of LRECL that is less than or equal to 32760. RECFM of FB and LABEL type is AL: BLKSIZE=highest multiple of LRECL that is less than or equal to 2048. RECFM of V, VS, D: BLKSIZE=LRECL +4

Chapter 5. PARM Options

5.27

RECFM of VB, VBS: BLKSIZE=32760 RECFM of DB: BLKSIZE=2048

If SDB=OFF or NO is specified, SyncSort will not use system-determined blocksize. The blocksize, if unavailable, will be determined from SORTIN if the SORTIN and output data set LRECLs are the same, otherwise SyncSort will select an appropriate blocksize. If SDB=DISKONLY is specified, SyncSort will use system-determined blocksize only for disk output data sets. If SDB=TAPEONLY is specified, SyncSort will use system-determined blocksize only for tape output data sets. SDB=LARGE enables the use of system-determined blocksize for both tape and DASD output data sets, as with SDB=ON. Additionally, under Version 2 Release 10 of OS/390 or under z/OS, SDB=LARGE enables selection of a system-determined blocksize greater than 32760 for eligible tape output data sets if not restricted by the system BLKSZLIM value. SDB=SMALL has the same meaning as SDB=ON. SDB=INPUT enables the use of system-determined blocksize for both tape and DASD output data sets, as with SDB=ON. Additionally, under Version 2 Release 10 of OS/390 or under z/OS, if an input tape data set has a blocksize greater than 32760, SDB=INPUT enables selection of a system-determined blocksize greater than 32760 for eligible tape output data sets if not restricted by the system BLKSZLIM value. SDB=INPUT is the default. SDB=LARGEONLY enables the use of system-determined blocksize for tape output data sets only, as with SDB=TAPEONLY. Additionally, under Version 2 Release 10 of OS/390 or z/OS, SDB=LARGEONLY enables selection of a system-determined blocksize greater than 32760 for eligible tape output data sets if not restricted by the system BLKSZLIM value. SDB=INPUTONLY enables the use of system-determined blocksize for tape output data sets only, as with SDB=TAPEONLY. Additionally, under Version 2 Release 10 of OS/390 or z/OS, if an input tape data set has a blocksize greater than 32760, SDB=INPUTONLY enables selection of a system-determined blocksize greater than 32760 for eligible tape output data sets if not restricted by the system BLKSZLIM value. Cannot be used with Tape Sort.

SKIPREC
SKIPREC=n

5.28

SyncSort for z/OS 1.2 Programmers Guide

SKIPREC=n instructs the sort to skip a decimal number n of records before sorting/copying the input file. The records skipped are deleted from the input file before E15 and INCLUDE/OMIT processing is begun. If SKIPREC=n has been specified on the SORT/MERGE control statement as well as in the PARM field, the PARM specification will take precedence. SKIPREC is not compatible with a merge application unless using FIELDS=COPY. Cannot be used with Tape Sort.

STOPAFT
STOPAFT=n STOPAFT=n (a decimal number) sorts/copies at most n records. These will be the first n records after any input processing due to an E15, an INCLUDE/OMIT statement, or the SKIPREC parameter. If STOPAFT=n has been specified on the SORT/MERGE control statement as well as in the PARM field, the PARM specification will take precedence. STOPAFT is not compatible with a merge application, unless using FIELDS=COPY. Cannot be used with Tape Sort.

TRUNC
RC0 TRUNC = RC4 RC16 TRUNC specifies the action to be taken if the LRECL defined in the JCL for a non-OUTFIL SORTOUT is smaller than the SORTIN/SORTINnn LRECL or the internally processed record length when the SORTIN/SORTINnn LRECL is modified by features. RC0 The delivered default instructs SyncSort to issue a WER462I message, truncate the output records, and issue a return code of zero. Instructs SyncSort to issue a WER462I message and truncate the output records. A return code of 4 will be issued if not overridden by a higher return code set for another reason.

RC4

Chapter 5. PARM Options

5.29

RC16 Instructs SyncSort to issue a WER462A message and terminate processing with a return code of 16. Note that for a BetterGener application TRUNC will be ignored. The installation parameter SOTRNGN will control processing for these applications. TRUNC will be ignored in applications in which the SORTIN/SORTINnn or SORTOUT is a VSAM data set. Cannot be used with Tape Sort.

UNINTDS
YES UNINTDS = NO UNINTDS indicates how SyncSort should process a non-VSAM uninitialized DASD input data set in a non-SMS environment. An uninitialized data set is one that has been created but never successfully opened and closed for output. In an SMS environment, uninitialized data sets are always processed as valid empty files. UNINTDS=YES indicates that an uninitialized data set should be processed as an empty file. If an uninitialized multi-volume data set has the DS1IND80 and DS1IND02 flags off in the format-1 DSCB of the first volume and the number of data extents is non-zero, SyncSort will open the data set for output to set an end-of-file mark before the data set is used for input. UNINTDS=NO indicates that SyncSort should terminate with a WER400A critical message if an uninitialized data set is provided as input. Cannot be used with Tape Sort.

VLTEST
,ON n VLTEST = ( ,OFF ) 1 ,OFF4 VLTEST allows you to do the following when variable-length records are processed: Choose the type of record length validity testing to be performed. Choose whether or not to verify the correct sequence of segments in variable-length spanned records.

5.30

SyncSort for z/OS 1.2 Programmers Guide

Record length validity testing may be performed in all types of applications: sort, merge, copy, and BetterGener. Segment sequence checking may only be done during sort and merge applications. The first subparameter of the VLTEST PARM is a number n that instructs SyncSort in the type of validity testing to be performed on variable-length records. Choosing a validity test instructs SyncSort to terminate with a critical error (outlined in WER027A, WER160A or WER167A) in the event of an illegal condition. In particular, VLTEST instructs the sort/merge in the handling of short variable-length records, i.e., records not long enough to contain all of the control fields specified in the SORT/MERGE control statement. The delivered default for VLTEST is 1. When VLTEST is set to an even number, SyncSort will accept short variable-length records, padding them with binary zeros to the length of the sort key for the sort compare process. In order to prevent system 0C7 abends due to the binary zero padding, the CMP PARM is automatically set to CMP=CLC in these cases. The binary zeros are removed from the record, restoring it to its original state, as the output record is being written. 0** 1 No validity testing of variable-length records. If input record is shorter than control fields, terminate. This is the delivered default. If input record is longer than maximum LRECL or l2 value, terminate. If either or both of tests 1 and 2, terminate. If input record is longer than output LRECL or l3 value, terminate. If input record is shorter than control fields, or longer than output LRECL or l3 value, or both, terminate. If input record is longer than the maximum input LRECL or l2 value, or longer than the output LRECL, or both, terminate. If input record is shorter than control fields, or longer than input LRECL or l2 value, or longer than output LRECL or l3 value, or any or all of these, terminate.

2** 3 4** 5

6**

The second subparameter allows you to specify whether or not SyncSort should verify that the sequence of segments is correct in each variable-length spanned record during sort and merge applications. ON is the delivered default and signals that the segment sequence should be verified. If OFF is selected, all illogical record segments encountered in the input file will be eliminated and message WER464I will be produced. If OFF4 is selected, the processing described for OFF will occur, but in addition if an illogical segment is found, a return code of 4 will be returned if not overridden by a higher return code set for another reason.

Chapter 5. PARM Options

5.31

The second subparameter does not apply during copy applications. Note: If an illegal condition is detected during a validity test and segment sequence checking is on, message WER182A will be issued. Cannot be used with Tape Sort. ** These values force the use of CMP=CLC for variable-length input.

VLTESTI
0 VLTESTI = 1 2 VLTESTI specifies to SyncSort how to process variable-length records that do not contain all specified INCLUDE or OMIT fields. VLTESTI applies to the INCLUDE and OMIT control statements as well as OUTFIL and JOINKEYS INCLUDE/OMIT processing. The delivered default of 0 instructs SyncSort to terminate if a record does not completely contain all INCLUDE or OMIT fields. A WER250A critical error message is generated to indicate this condition. When VLTESTI=1 is specified, a record that does not completely contain all INCLUDE/ OMIT fields is treated as having failed the comparison. SyncSort will omit the record if INCLUDE is being used or include the record if OMIT has been specified. When VLTESTI=2 is specified, SyncSort will treat comparisons to fields not completely contained within the record as false and decide a records status for inclusion or omission from fields that are available. If all fields are not present, the record will be processed as having failed the comparison. SyncSort will omit the record if INCLUDE is being used or include the record if OMIT has been specified. Cannot be used with Tape Sort.

VSAMEMT
NO VSAMEMT = YES VSAMEMT specifies the processing of empty VSAM input data sets. If you specify VSAMEMT=YES, an empty VSAM data set will be processed as a legitimate data set containing 0 records, and SyncSort will end with a return code of 0.

5.32

SyncSort for z/OS 1.2 Programmers Guide

The delivered default, VSAMEMT=NO, instructs SyncSort to terminate with a WER254A critical error if an empty VSAM data set is specified for input. Cannot be used with Tape Sort.

ZDPRINT
ZDPRINT NZDPRINT ZDPRINT specifies if positive ZD summation results are to be converted to printable numbers. ZDPRINT, the default, enables conversion to printable format. NZDPRINT prevents the conversion. This option determines whether the sign byte of a positive summarized ZD field will be converted to a printable format. More precisely, the option specifies whether the zone of the last digit should be changed from a hexadecimal C to a hexadecimal F. Cannot be used with Tape Sort.

Chapter 5. PARM Options

5.33

5.34

SyncSort for z/OS 1.2 Programmers Guide

Chapter 6. Invoking SyncSort from a Program

Programming Flexibility vs. Performance


The sort/merge can be invoked by an executing program written in COBOL, PL/1 or assembler language. However, since most invoked sorts utilize inline exits (typically through the COBOL SORT verb) and so are handicapped by the calling programs I/O techniques and memory allocations, sort performance may be degraded by this mode of initiation. Whenever performance is an important consideration, the sort should be initiated through the EXEC job control statement. Additional programming flexibility is provided by exits which can be separately compiled and link-edited. These may be coded in COBOL, FORTRAN, REXX, and assembler language. Exits may also be written in PL/1 provided that SyncSort is invoked by a PL/1 program.

DD Statements
The DD statements included in the Table of DD Statements for Invoked Sort/Merge are those which may be required when invoking the sort.

Chapter 6. Invoking SyncSort from a Program

6.1

DD Statement //$ORTPARM DD

Usage Used to override or add to control statements or PARMs supplied from an invoking program. SORT input data set. MERGE input data sets. JOINKEYS input data sets Work area definition. Defines the intermediate storage for a sort. Output data set.

When not required If no control statements or PARMs are being overridden or added. If there is an E32 exit routine or if running a merge or join application. If there is an E32 exit routine of if running a sort or copy. If the JOINKEYS feature is not in use. For incore sort, MERGE, COPY, or when using DYNALLOC. If there is an E35 exit routine. When no OUTFIL control statement is present. When the XSUM parameter of the SUM control statement is not used. If Tape Sort is not used. When all messages are routed to console or are disabled.

//SORTIN DD //SORTINnn DD //SORTINn DD //SORTJNF1 DD //SORTJNF2 DD //SORTWKxx DD //SORTWKn DD //SORTOUT DD or //SORTOFxx DD or //SORTOFx DD //SORTXSUM DD //SORTLIB DD //SYSOUT DD

Alternate output data set(s). Output data set for records deleted by SUM. Contains modules that are required to perform a Tape Sort. Message data set. Table 28.

Table of DD Statements for Invoked Sort/Merge

Invoking the Sort/Merge from an Assembler Program


Assembler invocation is accomplished by means of the ATTACH, LINK, or XCTL macro instruction. SyncSort control statements are coded as character-string operands of Assembler DC operations. The calling program passes to the sort/merge a pointer containing the address of either a 24-bit or an extended, 31-bit, parameter list. This list contains the addresses of the control statement images to be used by the sort. It may also contain other information such as the addresses of E15, E32, and E35 exit routines. Note that when using either the 24-bit or the 31-bit parameter list, the control statement images can be passed from $ORTPARM.

Macro Instructions
The choice of macro determines the linkage relationship between the calling program and the sort/merge load module. The linkage relationship established by ATTACH precludes the use of the Checkpoint-Restart feature; do not code CHKPT/CKPT on the SORT/MERGE control statement when invoking the sort/merge with the ATTACH macro. With XCTL, care must be taken to ensure that the storage area for the parameter list and other sort

6.2

SyncSort for z/OS 1.2 Programmers Guide

control information does not reside in the module issuing the macro - XCTL will delete this module from memory. This problem can be circumvented in two ways. Either (1) place the parameter list and additional control information in the task that attaches the module issuing the XCTL; or (2) have the module issuing the XCTL macro issue a GETMAIN macro instruction first, and place all of the sort/merge control information in the main storage area it obtains. None of the above restrictions apply when using the LINK macro. The sort/merge DD statements are placed with the JCL of the job step that issues the macro. The EP parameter is specified as SORT whether SyncSort is to be used for sorting, merging, or copying. With ATTACH, the ECB or EXTR is usually required.

Coding the Sort/Merge Control Statements


SyncSort control statements are introduced by the invoking programs as character operands in DC operations. Although it is generally true that all control statements supported for a JCL-initiated Disk Sort/MAXSORT/Tape Sort are available to invoked applications, these exceptions should be noted: A MODS control statement cannot be used for an E32 exit and is not required for an E15 or E35 exit. (An E32, E15 and/or E35 exit routine may be coded in line with the invoking program with their addresses passed to the sort in the parameter list. If the 31-bit parameter list is being used, an E18 and/or E39 exit routine address may also be passed.) The MODS control statement is not supported for an invoked Tape Sort. A RECORD control statement is required if an inline E15 exit routine address is provided. Its LENGTH parameter is required whenever an inline E15 or E35 exit routine is used. For a full description of record length parameters, see RECORD Control Statement on page 2.137. The END control statement is not used.

The actual coding of the control statements is the same, except that: No comments or labels are permitted within the DC operand. Continuation characters are not called for, since the statements are not in card-image format.

For the 24-bit parameter list, each control statement DC instruction should be labeled and followed by a DC C' ' instruction so that the beginning and ending addresses of the control statement can be referenced in the parameter list.

Chapter 6. Invoking SyncSort from a Program

6.3

SORTBEG SORTEND RECDBEG RECDEND

DC DC DC DC

C' C' C' C'

SORT FIELDS=(31,5,CH,A)' ' RECORD TYPE=F,LENGTH=(80,,120)' '

Figure 192. Sample Control Statement Images for the 24-bit Parameter List Note that the 24-bit invoking parameter list and pointer word, as well as the control statement images, must be below the 16 megabyte line. As in a JCL-initiated sort/merge, control statements must begin with at least one blank. For the 31-bit invoking parameter list, the control statement images will be pointed to by the first word of the parameter list and are organized like the control statement images for a 24-bit parameter list. Note, however, that only the first DC instruction requires a label since only the start and end of the list need be referred to. The control statements must be separated by one or more blanks; that is, each control statement must be followed by a blank. A blank before the first statement is optional; however, a blank after each statement is required. Labels, comment statements, and comment fields must not be coded. Each control statement, except the last, must have at least one parameter.

CARDLEN CARDBEG

CARDEND

DC DC DC DC DC DC EQU

0H Y(CARDEND-CARDBEG) C'SORT FIELDS=(31,5,CH,A)' C' ' C'RECORD TYPE=F,LENGTH=(80,,120)' C' ' *

Figure 193. Sample Control Statement Images for the 31-bit Parameter List

The 24-Bit Parameter List


The parameter list is used to pass information from the calling program (e.g., the addresses of the DC control statement images) to the sort/merge. For the parameter list used with invoked Tape Sorts, see Chapter 12. Tape Sort. In order to pass the parameter list, it is necessary to load the address of a fullword pointer into Register 1. Code X'80' in the pointers first byte and the address of the parameter lists byte count in its last three bytes. The byte count must be located in the last 2 bytes of the first fullword entry in the parameter list. It contains the hexadecimal number of bytes remaining in the list -- do not include these 2 bytes in the count.

6.4

SyncSort for z/OS 1.2 Programmers Guide

The first seven words of the parameter list are required and must be coded in the exact order shown. Note that whenever the address of an exit routine is supplied in the sixth or seventh word of the parameter list, that exit may not be specified in the MODS control statement image. Parameter list entries following the seventh fullword are optional and can be specified in any order. All values not specified in the chart as EBCDIC-coded are to be given in hexadecimal notation. For the most part, these are addresses; the ending address refers to the blank coded immediately after the control statement in question, as indicated in the Sample Invoked Sort.

Chapter 6. Invoking SyncSort from a Program

6.5

REGISTER 1 ADDRESS OF POINTER Fullword Boundary X'80'

POINTER (Fullword) Address of Parmlist Byte Count

Byte 1

Byte 2

Byte 3

Byte 4

Number of bytes in following list X'00' Required in order shown Beginning address of SORT or MERGE statement Ending address of SORT or MERGE statement Beginning address of RECORD statement Ending address of RECORD statement Address of E15 or E32 exit routine (Zeros if none) Address of E35 exit routine (Zeros if none) X'00' X'01' X'02' Main storage value Reserved main storage value Beginning address of MODS statement Ending address of MODS statement X'03' X'04' Optional X'05' Beginning address of message DD name to replace SYSOUT Number of input files (Use for merge with E32 exit only) Beginning address of DEBUG statement (Not processed) Ending address of DEBUG statement X'06' Beginning address of ALTSEQ statement Ending address of ALTSEQ statement X'07' Beginning address of SUM statement Ending address of SUM statement X'08' Beginning address of INCLUDE/OMIT statement Ending address of INCLUDE/OMIT statement Optional X'09' Beginning address of OUTREC statement Ending address of OUTREC statement X'0A' Beginning address of INREC statement Ending address of INREC statement X'0B' Beginning address of first OUTFIL statement

Table 29. (Page 1 of 2) The 24-Bit Parameter List

6.6

SyncSort for z/OS 1.2 Programmers Guide

Byte 1

Byte 2

Byte 3

Byte 4

Ending address of first OUTFIL statement . . . X'0B' . . . Beginning address of nth OUTFIL statement Ending address of nth OUTFIL statement X'0E' Beginning address of first JOINKEYS statement Ending address of first JOINKEYS statement X'0E' Beginning address of second JOINKEYS statement Ending address of second JOINKEYS statement X'0F' Beginning address of REFORMAT statement Ending address of REFORMAT statement X'10' Beginning address of JOIN statement Ending address of JOIN statement X'F6' X'F7' X'FD' X'FE' X'FF' Optional Beginning address of translation table User exit address constant IMS flag Pointer to STAE work area (May code zeros if none) Message option (Code in EBCDIC)

DIAG option (Code in EBCDIC) BALN, OSCL or POLY (Processed Tape Sort only; code in EBCDIC) CRCX, PEER or LIST (Not processed) DD name prefix to replace SORT in JCL (Code in EBCDIC) Table 29. (Page 2 of 2) The 24-Bit Parameter List

Note: Empty boxes indicate the contents are immaterial and not examined.

Chapter 6. Invoking SyncSort from a Program

6.7

BYTECNT

POINTER SORTBEG SORTEND RECBEG RECEND

. . . LA ATTACH BR . . . CNOP DC DC DC DC DC DC DC DC DC DC DC DC

1,POINTER EP=SORT 14

Load address of pointer to parameter list Initiate SyncSort Return to invoking program

2,4 Align to last 2 bytes of a word Y(24) Byte count of parameter list A(SORTBEG) Beginning address of sort statement A(SORTEND) Ending address of sort statement A(RECBEG) Beginning address of record statement A(RECEND) Ending address of record statement 2F'0' No E15 or E32 indicated. No E35. X'80' Indicates parameter list's pointer AL3(BYTECNT) Address of parameter list C' SORT FIELDS=(1,16,CH,A),SKIPREC=100' C' ' C' RECORD TYPE=F,LENGTH=80' C' '

Figure 194. Sample Invoked Sort In this example, only the required seven entries appear in the parameter list. The invoked sort skips the first 100 records in SORTIN, a data set of 80-byte fixed-length records, and sorts the remainder in ascending sequence according to the character data in its first 16 bytes. Additional parameter-list entries may appear in any order after these required seven; the contents of the first byte of the word signals which optional parameter it is. For invoked merge applications using the 24-bit parameter list, the number of input files must be specified on either the X'04' entry or the FILES=n parameter on the MERGE control statement. However, when using the 31-bit parameter list, the number of input files for a merge must be specified on the FILES=n parameter. Optional Parameters Code in Byte 1 X'00' Contents of Bytes 2 - 4 Indicates how much main storage SyncSort is to use. Code C'MAX' or a hexadecimal number of bytes.

Table 30. (Page 1 of 3) Optional Parameters for the 24-Bit Parameter List

6.8

SyncSort for z/OS 1.2 Programmers Guide

Optional Parameters Code in Byte 1 X'01' Contents of Bytes 2 - 4 Indicates how much main storage should be reserved for data handling by the invoking program during sort execution. SyncSort will use all available main storage less the hexadecimal number of bytes specified here. This parameter takes precedence over the X'00' entry discussed above. Gives the beginning address of a MODS control statement image. The last 3 bytes of the next word must contain the ending address of this image. All exits may be specified in the MODS statement image except for E32 (use entry 6 of the parameter list for this exit). An E15/E35 exit is specified in entries 6-7 or in the MODS image, but not in both. Specifies the address of a replacement for the message data sets DD name. Eight characters are used for the name; the first character must be alphabetic. Specifies the hexadecimal number of SORTIN files-required whenever an E32 exit supplies the input to the merge. SyncSort accepts the DEBUG control statement parameter but does not process it. Both this fullword (the beginning address of the DEBUG statement) and the next (the ending address) are ignored. Gives the beginning address of an ALTSEQ control statement image. The last 3 bytes of the next word must contain the ending address of this image. Gives the beginning address of a SUM control statement image. The last 3 bytes of the next word must contain the ending address of this image. Gives the beginning address of an INCLUDE/OMIT control statement image. The last 3 bytes of the next word must contain the ending address of this image. Gives the beginning address of an OUTREC control statement image. The last 3 bytes of the next word must contain the ending address of this image. Gives the beginning address of an INREC control statement image. The last 3 bytes of the next word must contain the ending address of this image. Gives the beginning address of an OUTFIL control statement. The last 3 bytes of the next word must contain the ending address of this image. This parameter may be specified more than once to accommodate multiple output file specifications. Gives the beginning address of a JOINKEYS control statement. The last 3 bytes of the next word must contain the ending address of this image. This parameter should be specified twice for the two JOINKEYS specifications required in a join application.

X'02'

X'03'

X'04' X'05'

X'06'

X'07'

X'08'

X'09'

X'0A'

X'0B'

X'0E'

Table 30. (Page 2 of 3) Optional Parameters for the 24-Bit Parameter List

Chapter 6. Invoking SyncSort from a Program

6.9

Optional Parameters Code in Byte 1 X'0F' Contents of Bytes 2 - 4 Gives the beginning address of a REFORMAT control statement image. The last 3 bytes of the next word must contain the ending address of this image. Gives the beginning address of a JOIN control statement image. The last 3 bytes of the next word must contain the ending address of this image. Specifies the address of a 256-byte translation table, used to alter the collating sequence. This parameter takes precedence over the ALTSEQ control statement image. Optional user exit address constant which can be used to pass information between the invoking program, an E15 exit, and/or an E35 exit. SyncSort passes these 3 bytes to an E15 exit at offset 5 in an E15 parameter list and to an E35 exit at offset 9 in an E35 parameter list. Offset 4 in the E15 parameter list and offset 8 in the E35 parameter list will initially contain an X'00'. Only the first byte is processed, flagging this as an IMS-initiated sort, processing variable-length records too short to contain all of the sort/ merge control field(s). If non-zero, these 3 bytes contain the address of a 104-byte STAE work area. Indicates the MSG/FLAG PARM coding. For the MSG option, specify AB, AC, AP, CB, NO, PC, SC or SP in bytes 3-4. For the FLAG option, specify NOF, (I) or (U) in bytes 2-4. This parameter is coded in EBCDIC.

X'10'

X'F6'

X'F7'

X'FD'

X'FE' X'FF'

DIAG coded in EBCDIC in the entire word turns on the IOERR=ABE and RC16=ABE PARM options. BALN/OSCL/POLY coded in EBCDIC in the entire word indicates the Tape Sort technique. Ignored by Disk Sort and MAXSORT. CRCX/PEER/LIST coded in EBCDIC in the entire word is accepted but not processed by SyncSort. xxxx with the first character alphabetic or national (do not use DIAG, PEER, CRCX, etc.) represents the DD name prefix to be used in place of SORT in the JCL. Table 30. (Page 3 of 3) Optional Parameters for the 24-Bit Parameter List

Return Codes
When the sort terminates, returning control to the calling program, it places a return code in Register 15: 0 indicates normal termination;

6.10

SyncSort for z/OS 1.2 Programmers Guide

16

indicates an unsuccessful sort.

The calling program typically tests the contents of Register 15, branching to the normalsort or sort-error end of job routine.

Chapter 6. Invoking SyncSort from a Program

6.11

Sample Assembler Invocation Using 24-Bit Parameter List


. . . LA LINK LTR BNZ B CNOP PTRWORD DC DC DS PARMS DC PARMSBEG DC DC DC DC DC DC DC DC DC DC DC DC DC DC DC DC DC DC DC DC PARMSEND EQU SORTBEG DC DC SORTEND DC RECBEG DC RECEND DC OMITBEG DC OMITEND DC SUMBEG DC SUMEND DC OUTBEG1 DC DC DC DC DC OUTEND1 DC

1,PTRWORD Load address of parameter list pointer EP=SORT Initiate SyncSort 15,15 Test return code SORTERR Branch on error condition SORTOK Branch to normal processing 0,4 Fullword alignment for pointer X'80' Indicates pointer to parameter list AL3(PARMS) Address of parameter list H Unused first 2 bytes of first parameter Y(PARMSEND-PARMSBEG) Byte count of remaining parameters A(SORTBEG) Beginning address of sort statement A(SORTEND) Ending address of sort statement A(RECBEG) Beginning address of record statement A(RECEND) Ending address of record statement F'0' No E15/E32 exit routine F'0' No E35 exit routine X'03' Indicates SYSOUT DD name change AL3(MSGNAME) Address of SYSOUT DD name replacement X'08' Indicates INCLUDE/OMIT parameter AL3(OMITBEG) Beginning address of OMIT statement A(OMITEND) Ending address of OMIT statement X'07' Indicates SUM parameter AL3(SUMBEG) Beginning address of SUM statement A(SUMEND) Ending address of SUM statement X'0B' Indicates OUTFIL parameter AL3(OUTBEG1) Beginning address of first OUTFIL statement A(OUTEND1) Ending address of first OUTFIL statement X'0B' Indicates OUTFIL parameter AL3(OUTBEG2) Beginning address of second OUTFIL statement A(OUTEND2) Ending address of second OUTFIL statement * End of parameter list C' SORT FIELDS=(1,20,A,35,8,A),' Begin SORT statement image C'FORMAT=CH' Continue SORT statement image C' ' End SORT statement image C' RECORD TYPE=F' Begin RECORD statement image C' ' End RECORD statement image C' OMIT COND=(21,8,PD,EQ,0)' Begin OMIT statement image C' ' End OMIT statement image C' SUM FIELDS=(21,8,PD)' Begin SUM statement image C' ' End SUM statement image C' OUTFIL FILES=1,' Begin first OUTFIL statement image C' HEADER1=(50X,''CHANGES' C' TO W-2 FORMS'',//,' C'50X,''JANUARY THROUGH JUNE' C' 1993'')' C' ' End first OUTFIL statement image

Figure 195. (Page 1 of 2) Sample Assembler Invocation Using 24-Bit Parameter List

6.12

SyncSort for z/OS 1.2 Programmers Guide

OUTBEG2

OUTEND2 MSGNAME

SORTERR

SORTOK

DC DC DC DC DC DC DC . . . DS . . . BR DS . . . BR

C' OUTFIL FILES=2,' Begin second OUTFIL statement image C'HEADER1=(19X,''EMPLOYEE'',' C'10X,''DEPARTMENT CODE'',' C'10X,''CHANGE''),' C'OMIT=(29,4,PD,NE,0)' OMIT condition C' ' End second OUTFIL statement image CL8'MESSAGES' SYSOUT DD name replacement

0H

Error routine for unsuccessful sort

14 0H

Return Normal processing for successful sort

14

Return

Figure 195. (Page 2 of 2) Sample Assembler Invocation Using 24-Bit Parameter List

This example sorts fixed-length records by the character data in its first 20 bytes and, where two records have identical data in this field, by the character data in bytes 35-42; these fields are collated in ascending order. Note the continuation of the SORT statement image using consecutive DC instructions. There is no special significance to the break after the FIELDS parameter -- a control statement image can be divided at any point in this way. The SORTIN file is edited by the OMIT statement, which will eliminate any records with zero in bytes 21-28 before sorting begins; these 8 bytes constitute the SUM field. SyncSort messages are written to the data set specified by the MESSAGES DD name. Two OUTFIL parameters have been specified, producing multiple output files. The first OUTFIL will receive data from every sorted input record, producing a company-wide report. The second OUTFIL will receive selected data only, as defined by the OMIT condition, producing a departmental report.

The 31-Bit Extended Parameter List


The extended parameter list allows the sort to interface with invoking programs that may require 31-bit addresses or which may use the 31-bit addressing mode (AMODE). The extended parameter list is not supported for Tape Sorts. For the parameter list used with invoked Tape Sorts, see Chapter 12. Tape Sort. Only the first word of the extended parameter list is required. The high order bit must be zero to identify this as a 31-bit parameter list. The subsequent words of this list are optional, and because there is no code in the high order byte, as in the 24-bit parameter list, their positional order must be maintained. Thus, when coding the list be sure to code a full-

Chapter 6. Invoking SyncSort from a Program

6.13

word of zeros when omitting one of the optional parameters. The last parameter word specified in the list must be followed by the 4-byte field X'FFFFFFFF'. The 31-bit parameter list has the following format: REGISTER 1 d 31-bit address of start of parameter list

Bit 0 Required +0 +4 +8 +12 Optional +16 +20 +24 +28 +32 Required +36 Table 31. d d m m 0 m m

Bits 1 through 31 Address of halfword containing the length of control statement images (zeros if none) Address of user E15 or E32 (zeros if none) Address of user E35 (zeros if none) User exits address constant (zeros if none) Address of ALTSEQ translation table (zeros if none) Address of STAE area field (zeros if no STAE routine) Address of user exit E18 (zeros if none) Address of user exit E39 (zeros if none) Call identifier (C 'nnnn') X'FFFFFFFF' (required)

31-Bit Extended Parameter List

Note: d indicates a bit is immaterial and not examined. The following table provides an explanation of the contents of the extended parameter list.

6.14

SyncSort for z/OS 1.2 Programmers Guide

Address +0

Contents (Required) First word of the parameter list. The high order bit must be zero to identify this as an extended parameter list. The other 31 bits contain the address of a halfword which contains the length of the following control statement images. A value of 0 (zero) represents a null list and control statement images must be supplied through the $ORTPARM DD statement. (Optional) Address of the E15 or E32 exit routine. This address may point anywhere in memory. The m bit (bit 0) means: 0=Enter the exit with 24-bit addressing in effect (AMODE 24); 1=Enter the exit with 31-bit addressing in effect (AMODE 31). (Optional) Address of the E35 exit routine. This address may point anywhere in memory. The m bit (bit 0) means: 0=Enter the exit with 24-bit addressing in effect (AMODE 24); 1=Enter the exit with 31-bit addressing in effect (AMODE31). (Optional) User exit address constant which can be used to pass information between the invoking program, an E15 exit routine, and/or an E35 exit routine. SyncSort passes these 4 bytes to an E15 exit routine at offset 4 in an E15 parameter list and/or to an E35 exit routine at offset 8 in an E35 parameter list. (Optional) Address of ALTSEQ translation table. It can point anywhere in memory and has a length of 256 bytes. (Optional) If non-zero, the address of a 112-byte STAE work area. (Optional) Address of the E18 exit routine. This address may point anywhere in memory. The m bit (bit 0) means: 0=Enter the exit with 24-bit addressing in effect (AMODE 24); 1= Enter the exit with 31-bit addressing effect (AMODE 31). (Optional) Address of the E39 exit routine. This address may point anywhere in memory. The m bit (bit 0) means: 0=Enter the exit with 24-bit addressing in effect (AMODE 24); 1= Enter the exit with 31-bit addressing in effect (AMODE 31). (Optional) Four displayable characters that will uniquely identify this particular call to SyncSort. (When this parameter is provided, SyncSort produces the WER428I message and includes these four characters in the text. This message facilitates correlation of message output when SyncSort is called multiple times by the same program.) (Required) The last parameter word specified in the list must be X'FFFFFFFF', which indicates end of list. If optional entries are omitted, this end-of-list indicator is moved up to the word immediately after the last specified parameter. Explanation of the Contents of the 31-Bit Extended Parameter List

+4

+8

+12

+16 +20 +24

+28

+32

+36

Table 32.

Note: An optional parameter becomes required if a subsequent parameter is to appear.

Chapter 6. Invoking SyncSort from a Program

6.15

Return Codes
When the sort terminates, returning control to the calling program, it places a return code in Register 15: 0 16 indicates normal termination; indicates an unsuccessful sort.

The calling program typically tests the contents of Register 15, branching to the normalsort or sort-error end of job routine. The following examples demonstrate how to code an extended parameter list. In this example, all exits reside below the 16-megabyte line and should be called with 24-bit AMODE set, except the E35 exit, which should be called with 31-bit AMODE set.

XLIST

. . . LA LINK . . . DC DC DC DC DC

1,XLIST EP=SORT

Point at Parameter List Initiate SyncSort

A(CNTLCARD) A(E15EXIT) A(E35EXIT+X'80000000') F'0' A(ALTSEQ)

DC DC DC DC CNTLCARD DC DC CNTLCRD2 DC DC CNTLLEN EQU

A(STAE) A(E18EXIT) A(E39EXIT) X'FFFFFFFF' 0H Y(CNTLLEN) C' SORT FIELDS=(1,16,CH,A)' C' RECORD TYPE=F,LENGTH=80' *-CNTLCRD2

Address of Control Card Images Address of E15 Exit Address of E35 Exit User Address Constant Address of ALTSEQ Translation Table Address of STAE Area Field Address of E18 Exit Address of E39 Exit End of Parameter List

Figure 196. Sample Invoked Sort with Both 24-bit AMODE & 31-bit AMODE Set This next example demonstrates how to code an extended parameter list in which all exits reside above the 16-megabyte line and should be called with AMODE 31 set.

6.16

SyncSort for z/OS 1.2 Programmers Guide

. . . LA LINK . . . XLIST DC DC DC DC DC DC DC DC DC CNTLCARD DC DC CNTLCRD2 DC DC CNTLLEN EQU

1,XLIST EP=SORT

Point at Parameter List Initiate SyncSort

A(CNTLCARD) Address of Control Card Images A(E15EXIT+X'80000000') Address of E15 Exit A(E35EXIT+X'80000000') Address of E35 Exit F'0' User Address Constant A(ALTSEQ) Address of ALTSEQ Translation Table A(STAE) Address of STAE Area Field A(E18EXIT+X'80000000') Address of E18 Exit A(E39EXIT+X'80000000') Address of E39 Exit X'FFFFFFFF' End of Parameter List 0H Y(CNTLLEN) C' SORT FIELDS=(1,16,CH,A)' C' RECORD TYPE=F,LENGTH=80' *-CNTLCRD2

Figure 197. Sample Invoked Sort with 31-bit AMODE Set

Chapter 6. Invoking SyncSort from a Program

6.17

Sample Assembler Invocation Using 31-Bit Parameter List


. . . LOAD ST LA LINK LTR BNZ B . . . DC DC DC DC DC DS DC DC DC DC DC DC DC DC DC DC DC DC DC DC DC DC EQU DS . . . BR DS . . . BR

EP=E15EXIT R0,E15ADDR 1,XLIST EP=SORT R15,R15 SORTERR SORTOK

Load E15 exit Store E15 AMODE+address Point at parameter list Initiate SyncSort Test return code Branch on error condition Branch to normal processing

XLIST E15ADDR

CARDLEN CARDBEG

CARDEND SORTERR

A(CARDLEN) Address of control statements A(0) Address of E15 routine A(0) No E35 routine A(0) User exit address constant X'FFFFFFFF' End of parameter list 0H Control statement area Y(CARDEND-CARDBEG) Length of character string C'SORT FIELDS=(1,20,A,35,8,A),' Begin SORT image C'FORMAT=CH' Continue SORT image C'RECORD TYPE=F,LENGTH=80 ' RECORD image C'OMIT COND=(21,8,PD,EQ,0) ' OMIT image C'SUM FIELDS=(21,8,PD) ' SUM image C'OUTFIL FILES=1,' First OUTFIL image C'HEADER1=(50X,''CHANGES' C' TO W-2 FORMS'',//,' C'50X,''JANUARY THROUGH JUNE' C'1992'')' End first OUTFIL image C'OUTFIL FILES=2,' Second OUTFIL image C'HEADER1=(19x,''EMPLOYEE'',' C'10X,''DEPARTMENT CODE'',' C'10X,''CHANGE'')' C',OMIT=(29,4,PD,NE,0)' End second OUTFIL image * 0H Error routine for unsuccessful sort

SORTOK

14 0H

Return Normal processing for successful sort

14

Return

Figure 198. Sample Assembler Invocation Using 31-Bit Parameter List This example sorts fixed-length records by the character data in its first 20 bytes and, where two records have identical data in this field, by the character data in bytes 35-42; these fields are collated in ascending order. Note the continuation of the SORT statement image using consecutive DC instructions. There is no special significance to the break after the FIELDS parameter - a control statement image can be divided at any point in this way. The SORTIN file is edited by the OMIT statement, which will eliminate any records with

6.18

SyncSort for z/OS 1.2 Programmers Guide

zero in bytes 21-28 before sorting begins; these 8 bytes constitute the SUM field. Two OUTFIL parameters have been specified, producing multiple output files. The first OUTFIL will receive data from every sorted input record, producing a company-wide report. The second OUTFIL will receive selected data only, as defined by the OMIT condition, producing a departmental report.

Chapter 6. Invoking SyncSort from a Program

6.19

6.20

SyncSort for z/OS 1.2 Programmers Guide

Chapter 7. The Coding and Use of Exit Programs

What Is an Exit?
The term program exits refers to the various points in the sort programs executable code at which control can be passed to a user-written routine. Most exit routines take control once for every record being processed, increasing overall execution time and consuming main storage that would otherwise be used by the sort. Exits should only be coded for tasks which cannot be accomplished with SyncSort control statements. Program exits are not allowed to take their own OS or VS checkpoints. Program exits are labeled with a 2-digit decimal number, e.g., E35. Except for E61, the first digit (1, 2 or 3) refers to the sort/merge phase at which the routine will get control; an E61 routine can take control in Phase 1 or Phase 3. The second digit refers to the number of that exit within the phase. Whenever possible, control passes directly from Phase 1 to Phase 3, skipping the intermediate merge phase and its associated exits: E21, E25 and E27. As indicated in the following chart, the nature of the task determines the program exit to be used.

Chapter 7. The Coding and Use of Exit Programs

7.1

PHASE 1 TASK Prepare for other exit routines Create input records for sort (Phase 1) and copy (Phase 3) Create input records for merge Add records Delete records Change records Sum records Choose action if intermediate storage insufficient Close other exit data sets Process read errors Process write errors Check labels Modify a collating sequence * E15 in Phase 3 for copy only Table 33. X X X X X X X
E11 E14 E15 E16 E17 E18 E61

PHASE 2
E21 E25 E27 E31 E32 E15 *

PHASE 3
E35 E37 E38 E39 E61

X X X X X X

X X X X

X X X X

Program Exits and Processing Phases

7.2

SyncSort for z/OS 1.2 Programmers Guide

Loading the Exit Routines into Main Storage


The MODS statement identifies the exits to be taken and indicates the name of the separately compiled, user-written routine to take control at that point. The same routine (e.g., deleting selected records) could take effect in different phases, but cannot be loaded more than once in a single phase. Note that merge and copy are executed entirely in Phase 3 and are therefore restricted in the exits which they can use. A merge application cannot use exits E11 through E27. A copy application can use exit E15 but not exits E32 or E61. Assemble each routine as a separate program and place it in a partitioned data set or in the SYSIN input stream; SyncSort copies the SYSIN routines to the SORTMODS library for linkage editing. (If a SYSIN module is to be used at more than one exit point, each exit must have its own compiled copy of the module in SYSIN.) If SyncSort linkage edits an exit routine, the module must have an entry point whose name is that of the SyncSort exit; for example, in order to function as an E35 routine, MYEXIT must include an entry point or CSECT labeled E35. If a routine has already been link-edited, this can be indicated in the MODS statement. When all the exits in a particular phase need to communicate with one another, the MODS statement can be used to instruct the sort to link-edit them together.

Exit Conventions
The following conventions must be observed when using exits. Exits provided via the MODS control statement will be entered in the addressing mode indicated by the linkage editor module attributes. Any exit linkage-edited by SyncSort will be entered in 24-bit addressing mode, except a separately linkage-edited exit E11, E21, or E31, which will be entered in the mode set by the compiler or assembler when the module was compiled or assembled. Exit addresses provided via the 24-bit invoking parameter list format will be entered in the 24-bit address mode. Exit addresses provided via the 31-bit invoking parameter list will be entered in the address mode indicated in the exit address field. That is, if bit 0 of the exit address is 0, the exit is entered in 24-bit mode; if bit 0 of the exit address is 1, the exit is entered in 31-bit mode. User exits may return to the sort in either 24- or 31-bit address mode. If an exit was entered in 24-bit address mode, the addresses passed to it will be 24-bit values that have a clean high-order byte containing binary zeros (X'00'). Addresses returned to the sort must also be 24-bit values with a high-order byte containing X'00' even though the exit could return to the sort in the 31-bit mode.

Chapter 7. The Coding and Use of Exit Programs

7.3

An exit in the 31-bit mode may return an address containing a full 31-bit value. Users intending to pass only a 24-bit address must therefore make sure that the address returned has X'00' in the high-order byte. Failure to do so can have unpredictable results. Note that certain addresses within parameter lists are still explicitly restricted to 24-bit values. For example, E18 exit return parameter lists must consist of fullword entries that are 1-byte codes and 3-byte addresses.

Register Conventions
The standard operating system conventions apply to register usage. Exit routines must save and restore Registers 0 and 2-14. The sort/merge places these contents in Register 1 and 13-15 for use by the exit routine when it takes control. Register 1 Register 13 The address of a SyncSort parameter list. The address of a 19-word area. The first 18 words can be used to save registers, the 19th word to pass information between Assembler exits. SyncSorts return address, in the low-order address bits of the register. The high-order bit(s) may have undefined contents. The address of the entry point of the exit routine, in the low-order address bits of the register. The high-order bit(s) may have undefined contents.

Register 14

Register 15

The Exit Communication Area


When an exit routine is given control, Register 13 points to a 19-word area, the first 18 of which can be used to save registers. The 19th word of this area can be used to pass information between Assembler exits. For example, when the COMMAREA PARM is used, the 19th word can be set to point to the exit communication area COMMAREA provides. The first 2 bytes of this communication area give the length of the area. The user is free to change the entire communication area, including the initial halfword.

7.4

SyncSort for z/OS 1.2 Programmers Guide

REGISTER 13 18-word save area

* Address of communication area * 00 04 LIST

Figure 199. User Communication Area for Assembler Exit Using COMMAREA PARM For COBOL or C exits, the address and length of this area are passed in the COBOL or C programs parameter list. In this case, there is no halfword preface the address points directly to the communication area.

Exits E11, E21, and E31 - Preparing for Other Exit Routines
These exits are unusual in that they are entered only once, at the beginning of their associated phase. Because of this, they may be separately link-edited and are efficiently used to prepare for other exit routines (e.g., to open files or initialize variables). There are no parameter lists or return codes for these exits.

Exit E32 - Invoked Merge Only: Creating Input Records


This exit can only be used for an invoked merge and must be coded in line with the invoking program. It therefore never appears on the MODS statement. When an E32 routine is used, all SORTINnn DD statements will be ignored by the merge; the exit must supply all the input records, and the number of input files to be created must be supplied by either the invoking programs parameter list or the FILES=n parameter on the MERGE control statement. Whenever the merge requires a new input record, SyncSort calls the E32 routine, passing it the address of a two-word parameter list in Register 1.

PARAMETER LIST Word 1: Number of next input file Word 2: Address of the next input record Figure 200. Parameter List for E32

Chapter 7. The Coding and Use of Exit Programs

7.5

The first word of the parameter list contains a hexadecimal representation of the input file SyncSort is currently processing. This is initialized as 0 for the first file and incremented by 4 every time a new SORTINnn file is to be accessed. When the E32 encounters end-of-file on a SORTINnn file it should return RC=8 to SyncSort, which will no longer request input from that file (i.e., that input file number). The E32 routine must respond to three different cases: (a) SyncSort already has all the input records; (b) the previous record finished an input file; and (c) there is at least one more record to be added to the file with this file number. Only in the last case will the E32 supply a record address to the merge, placing it in the second word of the parameter list. The E32 also places the appropriate return code in Register 15.

Return Codes
8 End of file. This tells SyncSort that a particular file has been completed and to make no further request for records from that file. Insert this record. This tells SyncSort to accept a new record from the input file requested. End of merge. This terminates SyncSort with a critical error.

12

16

Exit E14 - Deleting, Summarizing, Changing Records


Exit E14 may be used to change the contents of data fields, or to delete or summarize records during Phase 1. Unlike an E15 exit routine, it cannot be used to add records. An E14 exit program requires: at least one SORTWKxx data set, assigned to disk; fixed-length input records.

This exit is given control whenever SyncSort is about to add a record to an output sequence. Since it does not take control before the first record of that sequence, the routine always has access to a pair of sequenced records (e.g., for summarization purposes). SyncSort passes the exit program a two-word parameter list by loading its address into Register 1. The exit must not destroy the contents of this parameter list. The first word, which is on a fullword boundary, contains the address of the record about to be placed in an output sequence; the second word contains the address of the record that has just been put into the output buffer.

7.6

SyncSort for z/OS 1.2 Programmers Guide

PARAMETER LIST Word 1: Address of record leaving Phase 1 Word 2: Address of the latest record in output buffer Figure 201. Parameter List for E14 There are two constraints on the type of processing the exit may accord this record pair: Sort control fields should not be changed since this may cause an out-of-sequence condition. If a record is to be changed, it should first be moved to a work area.

After record processing is completed, the exit routine must place the appropriate return code in Register 15. The exit must save and restore all registers except those used in linking to the sort/merge.

Return Codes
0 Accept this record. This instructs SyncSort to accept the record whose address is in the first word of the parameter list and place it in the output buffer. The exit must also load the (work area) address of this record into Register 1 before returning control to the sort. Delete this record. This instructs SyncSort to delete the record whose address is in the first word of the parameter list. Do not place the address of this record in Register 1. This return code might be employed, for example, after using this record to update the previous (output) record. Assuming this does not complete an output sequence for Phase 1, the next execution of the E14 will find the same address in the second word of the parameter list.

Exit E15 - Creating, Revising, or Analyzing the Input File


Where an input data set already exists, this exit is used to add, delete and/or change input records. This exit is also used to analyze SORTIN via HISTOGRM (a HISTE15 application) or to create the entire input file. It can be used when sorting or copying records. When used in conjunction with an input file, this exit is given control every time a record is brought into Phase 1 of a sort or Phase 3 of a copy. In passing control to the E15 exit routine, SyncSort places the address of a parameter list in Register 1. This parameter list is two words long, aligned on a fullword boundary. In the first word, the first byte contains X'00'; the last 3 bytes contain the address of the record just brought into Phase 1. The first word contains a zero address when there is no such record (i.e., when SORTIN end-of-file is reached or when the input data set is empty).

Chapter 7. The Coding and Use of Exit Programs

7.7

Word 2 contains the user address constant. On the initial call to the E15 exit, it will contain the value specified in the invoking parameter list. If this value was specified in a 24-bit invoking parameter list, it will have the high-order byte set to X'00'. If the value was omitted or SyncSort was JCL invoked, Word 2 will contain binary zeros. This word may be changed by the E15 exit whenever it is entered. If used in a sort application, the value will be returned on the subsequent call to the E15. If used in a copy application and an E35 is present, the value on the subsequent call to the E15 will reflect any modification made to the User Address Constant by the E35. In a sort application, the initial entry to the E35 will contain the value last returned from the E15.

PARAMETER LIST Word 1: Address of the new record Word 2: User address constant Figure 202. Parameter List for E15 E15 record processing has these two constraints: If a record is to be changed, it should first be moved to a work area. When the input data set consists of variable-length records, the first 4 bytes must contain the Record Descriptor Word, giving the length of the record.

When the program has finished processing the record, it must place the appropriate return code in Register 15.

Coding the E15 Exit Routine for an Invoked Sort or Copy


When SyncSort is initiated from an ATTACH, LINK or XCTL macro, there are two ways to include an E15 exit routine: (1) code the E15 exit routine in line with the invoking program and specify the address of its entry point in the appropriate entry of the parameter list; or (2) define the separately compiled routine in the MODS control statement. When the exit routine is coded in line with the calling program, it must supply the entire input data set; SyncSort will ignore a SORTIN DD statement, if present. Data set creation is done by supplying the sort with one record at a time, placing its address in Register 1 and a return code of 12 in Register 15. After the last record has been submitted, the exit passes a return code of 8.

Return Codes
0 Accept this record. This instructs SyncSort to accept the record the exit has just examined. Place the (work area) address of this record in Register 1. This return code is used when selectively editing records from an input file; it passes the (possibly altered) record back to the sort. The RECORD state-

7.8

SyncSort for z/OS 1.2 Programmers Guide

ment is required if the exit routine changes the maximum record length; code the old maximum length as l1, the new maximum as l2. 4 Delete this record. SyncSort will delete the record just examined. There is no need to load the address of this record into Register 1. Do not return to this exit. This instructs SyncSort to close the exit for the remainder of the sort application. This return code might be used at SORTIN end-of-file (signalled by a zero address in the parameter list) to indicate that extra records will not be added at this point. There is no need to load a record address into Register 1 when passing a return code of 8. If SORTIN is present, the current input record and all subsequent records will be processed by SyncSort. Insert a record. This tells SyncSort that the exit routine has located a record which should be added to the input data set before the record whose address appears in the parameter list. Load the address of the new record into Register 1. When SyncSort returns control to the E15, the parameter list will be unchanged. The exit routine can then add another record or process the current one. This return code can be used to add records to the end of the input data set or to create the entire input data set. SyncSort returns to the exit routine, adding records without changing the parameter list (in these cases, a zero address) until a different return code (i.e., RC=8) is passed. When the input data set is created in this way, the RECORD statement is required and must specify both TYPE and LENGTH. 16 Terminate SyncSort. This tells SyncSort to terminate and return to the calling program or the supervisor. SyncSort uses a completion code of 16 to indicate that the sort was unsuccessful.

12

Coding a COBOL E15 Exit Routine


A COBOL E15 exit program can be indicated through the EXEC statements PARM option (PARM='E15=COB'), the MODS control statement or the $ORTPARM DD statement. An E15 exit cannot be coded in COBOL when running Tape Sort. Like any other E15 exit routine, the COBOL E15 exit routine is called each time a record is brought into Phase 1 of a sort or Phase 3 of a copy. Communication between SyncSort and the COBOL exit takes place in the LINKAGE SECTION of the COBOL program. For example, records are passed to the COBOL routine in the second definition (RECORD-UP) area of the LINKAGE SECTION. If the COBOL exit routine uses any verb (EXHIBIT, DISPLAY, TRACE) which results in output to the SYSOUT DD statement, there is a potential conflict with SyncSorts use of

Chapter 7. The Coding and Use of Exit Programs

7.9

this DD statement. It is therefore recommended that the user separate the output by using either SyncSorts MSGDD PARM option or the COBOL compilers SYSx parm.

The LINKAGE SECTION


The LINKAGE SECTION examples that follow show the parameters required for passing fixed-length and variable-length records to the sort. The data-names and conditional names used in the examples are arbitrary but each definition is required. The complete programs from which the examples are taken follow the discussion of the exit.

Example 1: Fixed-Length Records


LINKAGE SECTION. 01 EXIT-STATUS 88 FIRST-TIME 88 MOST-TIME 88 LAST-TIME 01 RECORD-UP. 07 FILLER 07 R-SEQ2 07 FILLER 01 WORK 01 DUMMY1 01 DUMMY2 01 DUMMY3 01 DUMMY4 01 DUMMY5 01 01 COMM-LEN COMMUNICATION-AREA. 05 COMM-AREA OCCURS 1 TO 256 TIMES DEPENDING ON COMM-LEN PIC X.

PIC 9 (8) COMPUTATIONAL. VALUE 00. VALUE 04. VALUE 08. PIC PIC PIC PIC PIC PIC PIC PIC PIC 9(6). 9(2). X(92). X(100). X. X. X. X. X. COMPUTATIONAL.

PIC 9(4)

For the first definition (EXIT-STATUS) specify PIC 9(8) COMPUTATIONAL. (This area defines exit status codes.) When using 88 levels to define the exit status codes, specify values 00, 04, and 08. For the second definition (RECORD-UP) define the SORTIN record. For the third definition (WORK) define the record that will be passed to SyncSort. (This is the "work area.")

7.10

SyncSort for z/OS 1.2 Programmers Guide

For the fourth through the eighth definitions define dummy areas. For the ninth definition (COMM-LEN) specify PIC 9(4) COMPUTATIONAL. This area defines the communication area length. For the tenth definition (COMMUNICATION-AREA) code an OCCURS clause DEPENDING ON data-name PIC X.

Example 2: Variable-Length Records


LINKAGE SECTION. 01 EXIT-STATUS PIC 9 (8) COMPUTATIONAL. 88 FIRST-TIME VALUE 00. 88 MOST-TIME VALUE 04. 88 LAST-TIME VALUE 08. 01 RECORD-UP. 05 RU OCCURS 1 TO 100 TIMES DEPENDING ON LEN-RU PIC X. 01 WORK. 05 WK OCCURS 1 TO 100 TIMES DEPENDING ON LEN-WK PIC X. 01 IN-BUF PIC X(100). 01 DUMMY PIC X(4). 01 LEN-RU PIC 9(8) COMPUTATIONAL. 01 LEN-WK PIC 9(8) COMPUTATIONAL. 01 LEN-IB PIC 9(8) COMPUTATIONAL. 01 COMM-LEN PIC 9(4) COMPUTATIONAL. 01 COMMUNICATION-AREA. 05 COMM-AREA OCCURS 1 TO 256 TIMES DEPENDING ON COMM-LEN PIC X.

For the first definition (EXIT-STATUS) specify PIC 9(8) COMPUTATIONAL. (This area defines exit status codes.) For the second definition (RECORD-UP) code an OCCURS clause with the DEPENDING ON data-name option specifying (1) The minimum and maximum number of bytes the variable SORTIN records contain (do not include 4 bytes for the RDW) and (2) DEPENDING ON data-name PIC X. Data-name is defined in the sixth definition in the LINKAGE SECTION. For the third definition (WORK) code an OCCURS clause with the DEPENDING ON data-name option specifying (1) The minimum and maximum number of bytes for variable-length records to be passed to SyncSort (do not include 4 bytes for the RDW)

Chapter 7. The Coding and Use of Exit Programs

7.11

and (2) DEPENDING ON data-name PIC X. Data-name is defined as the seventh definition in the LINKAGE SECTION. For the fourth definition specify a dummy level 01 data-name of any number of bytes. (IN-BUF is the data-name used in this example.) Note that the level 01 data-name, used here as a dummy address, has no effect on the E15 routine for variable-length records. The address is usually used as a buffer pointer in the COBOL E35 exit routine. By using it in the E15 LINKAGE SECTION, SyncSort is able to use the same parameter list for both COBOL exits E15 and E35. For the fifth definition specify a dummy area. For the sixth definition (LEN-RU) specify data-name PIC 9(8) COMPUTATIONAL. This is where SyncSort passes the length of the SORTIN record to the COBOL exit. For the seventh definition (LEN-WK) specify data-name PIC 9(8) COMPUTATIONAL. This is where the E15 routine passes the length of the work area record to SyncSort. For the eighth definition define a dummy area. For the ninth definition (COMM-LEN) specify PIC 9(4) COMPUTATIONAL. This area defines the communication area length. For the tenth definition (COMMUNICATION-AREA) code an OCCURS clause DEPENDING ON data-name PIC X.

The IDENTIFICATION, ENVIRONMENT, and DATA Divisions


As always, the COBOL program must contain the entries required by the compiler for these program divisions. Code the optional entries in these divisions according to the requirements of the application.

The WORKING-STORAGE SECTION


If the exit routine inserts records into the final merge and replaces records passed from SyncSort, the insertion record and the replacement record may be defined in this section. These records will be moved to the WORK area described in the LINKAGE SECTION, so be sure that the PICTURE clause or the OCCURS clause in the WORK area is correct for these records. This section may also define the return codes as 77-level data items. Alternatively, these codes can be specified as literals in the MOVE instruction. (MOVE literal to RETURNCODE.) Note that RETURN-CODE is the name of a predefined storage area in COBOL used to pass return codes to the sort; RETURN-CODE should not be defined in the exit routine.

7.12

SyncSort for z/OS 1.2 Programmers Guide

The PROCEDURE DIVISION


Specify the USING option on the PROCEDURE DIVISION header. Each identifier specified after USING must be the same as those described in the 01-level of the LINKAGE SECTION. Taking for example the identifiers defined in the fixed-length record LINKAGE SECTION shown here, they would appear as: PROCEDURE DIVISION USING EXITSTATUS, RECORD-UP, WORK, DUMMY1, DUMMY2, DUMMY3, DUMMY4, DUMMY5, COMM-LEN, COMMUNICATION-AREA. The GOBACK statement is used to return control to SyncSort. Do not use the EXIT statement as it will cause unpredictable results. Be sure that SyncSort receives a valid return code before the GOBACK statement is executed.

EXIT-STATUS Codes (Fixed and Variable-Length Records)


00 First record. SyncSort uses this Code to indicate the first call to the COBOL exit and that the first record from SORTIN is in the RECORD-UP area. Most records. This is used for all calls except the first one when there are records in the RECORD-UP area. After Code 00 has been issued, Code 04 is passed to the exit until there is no record for the sort to pass to the RECORD-UP area. All records passed. This indicates that the last SORTIN record has already been processed by the exit. Do not attempt to reference the record again. No more records will be passed to the exit routine. Note that if the SORTIN data set is empty, 08 will be passed every time including the first time.

04

08

RETURN-CODE Codes (Fixed and Variable-Length Records)


0 Accept this record. This instructs SyncSort to accept the (unaltered) record in the RECORD-UP area. Delete this record. SyncSort will delete the current record in the RECORDUP area. Do not return to this exit. This instructs SyncSort to close the exit for the remainder of the sort application. This return code might be used at SORTIN end-of-file (Exit Status Code 08) to indicate that extra records will not be added at this point. If SORTIN is present, the current input record and all subsequent records will be processed by SyncSort. Insert a record. This instructs SyncSort to add the record in the WORK area to the input data set just ahead of the current record in the RECORD-UP area. When SyncSort returns control to the E15, the same record will be in the RECORD-UP area. The exit routine can then add another record from the WORK area or process the current record in RECORD-UP.

12

Chapter 7. The Coding and Use of Exit Programs

7.13

16

Terminate SyncSort. SyncSort will end its program and return to the calling program or the Supervisor. SyncSort will issue a completion code of 16 to indicate that the sort was unsuccessful. Replace current record. SyncSort will replace the current record in the RECORD-UP area with the record in the WORK area. Be sure that the record in the WORK area is valid before passing it to SyncSort.

20

To Change a Record
In order to change the record in the RECORD-UP area, first move it to the WORK area. All changes are made to the WORK area copy, which replaces the record in RECORD-UP when 20 is moved to RETURN-CODE.

7.14

SyncSort for z/OS 1.2 Programmers Guide

Sample COBOL E15, Fixed-Length Records

IDENTIFICATION DIVISION. PROGRAM-ID. E15FL13C. ENVIRONMENT DIVISION. CONFIGURATION SECTION. SOURCE-COMPUTER. IBM-370. OBJECT-COMPUTER. IBM-370. INPUT-OUTPUT SECTION. FILE-CONTROL. I-O-CONTROL. DATA DIVISION. FILE SECTION. WORKING-STORAGE SECTION. 01 EVEN-FLAG 01 USER-RETURN-CODE 88 ACCEPT-REC 88 DELETE-REC 88 END-EXIT 88 INSERT-REC 88 END-SORT 88 REPL-REC CHANGE-REC. 05 C-REC 05 C-INCR 05 C-BLANK INSRT-REC. 05 I-REC 05 I-INCR 05 I-BLANK TOTAL. 05 BLANKS 05 TITL 05 COUNTER

PIC PIC VALUE 0. VALUE 4. VALUE 8. VALUE 12. VALUE 16. VALUE 20.

9(2) VALUE ZERO. 9(8) COMPUTATIONAL.

01

PIC PIC PIC

X(6) VALUE 'CHANGE'. 9(4) VALUE ZERO. X(90) VALUE ZERO.

01

PIC X(6) VALUE 'INSERT'. PIC 9(4) VALUE ZERO. PIC X(90) VALUE SPACES.

01

PIC X(10) VALUE ' E15'. PIC X(25) VALUE 'TOTAL RECORDS OUT'. PIC 9(8) VALUE 0.

Chapter 7. The Coding and Use of Exit Programs

7.15

Sample COBOL E15, Fixed-Length Records (Continued)

LINKAGE SECTION. 01 EXIT-STATUS 88 FIRST-TIME 88 LAST-TIME 01 RECORD-UP. 07 FILLER 07 R-SEQ1 07 FILLER WORK

PIC

9(8) COMPUTATIONAL. VALUE 00. VALUE 08.

01

PIC 9(6). PIC 9(2). PIC X(92). PIC X(100).

PROCEDURE DIVISION USING EXIT-STATUS, RECORD-UP,WORK. IF COUNTER GREATER THAN 100 MOVE 0 TO RETURN-CODE GO TO RETURN-TO-SORT. IF LAST-TIME GO TO RETURN-TO-SORT. IF R-SEQ1 EQUAL 0 MOVE 4 TO RETURN-CODE GO TO RETURN-TO-SORT. IF R-SEQ1 EQUAL 5 MOVE 12 TO RETURN-CODE MOVE INSRT-REC TO WORK GO TO RETURN-TO-SORT. IF R-SEQ1 EQUAL 6 MOVE 20 TO RETURN-CODE MOVE CHANGE-REC TO WORK GO TO RETURN-TO-SORT. MOVE 0 TO RETURN-CODE. RETURN-TO-SORT. ADD 1 TO COUNTER. IF LAST-TIME MOVE 8 TO RETURN-CODE DISPLAY TOTAL. GOBACK.

7.16

SyncSort for z/OS 1.2 Programmers Guide

Sample COBOL E15, Variable-Length Records

IDENTIFICATION DIVISION. PROGRAM-ID. E15VL19C. ENVIRONMENT DIVISION. CONFIGURATION SECTION. SOURCE-COMPUTER. IBM-390. OBJECT-COMPUTER. IBM-390. INPUT-OUTPUT SECTION. FILE-CONTROL. I-O-CONTROL. DATA DIVISION. FILE SECTION. WORKING-STORAGE SECTION. 01 EVEN-FLAG 01 USER-RETURN-CODE 88 ACCEPT-REC 88 DELETE-REC 88 END-EXIT 88 INSERT-REC 88 END-SORT 88 REPL-REC CHANGE-REC. 05 C-REC 05 C-INCR 05 C-BLANK

PIC 9(2) VALUE ZERO. PIC 9(8) COMPUTATIONAL. 0. 4. 8. 12. 16. 20.

VALUE VALUE VALUE VALUE VALUE VALUE

01

PIC X(6) VALUE 'CHANGE'. PIC 9(4) VALUE ZERO. PIC X(90) VALUE SPACES.

01 INSRT-REC. 05 I-REC 05 I-INCR 05 I-BLANK 01 TOTAL. 05 BLANKS PIC

PIC X(6) VALUE 'INSERT'. PIC 9(4) VALUE ZERO. PIC X(90) VALUE SPACES.

X(10) VALUE ' E15'.

Chapter 7. The Coding and Use of Exit Programs

7.17

Sample COBOL E15, Variable-Length Records (Continued)

05 TITL PIC 05 COUNTER PIC LINKAGE SECTION. 01 EXIT-STATUS 88 FIRST-TIME 88 MOST-TIME 88 LAST-TIME 01

X(25) VALUE 'TOTAL RECORDS OUT'. 9(8) VALUE 0.

PIC

9(8) COMPUTATIONAL. VALUE 00. VALUE 04. VALUE 08.

01

01 01 01 01

RECORD-UP. 05 RU OCCURS 1 TO 100 TIMES DEPENDING ON LEN-RU PIC X. WORK. 05 WK OCCURS 1 TO 100 TIMES DEPENDING ON LEN-WK PIC X. IN-BUF PIC X(100). DUMMY PIC 9(8) COMPUTATIONAL. LEN-RU PIC 9(8) COMP. LEN-WK PIC 9(8) COMP. PROCEDURE DIVISION USING EXIT-STATUS, RECORD-UP, WORK, IN-BUF, DUMMY, LEN-RU, LEN-WK. IF NOT FIRST-TIME ADD 1 TO COUNTER MOVE 0 TO RETURN-CODE. IF COUNTER LESS THAN 50 MOVE 54 TO LEN-WK ADD 1 TO I-INCR MOVE INSRT-REC TO WORK MOVE 12 TO RETURN-CODE GO TO RETURN-TO-SORT. IF COUNTER LESS THAN 75 MOVE 44 TO LEN-WK ADD 1 TO C-INCR MOVE CHANGE-REC TO WORK

7.18

SyncSort for z/OS 1.2 Programmers Guide

Sample COBOL E15, Variable-Length Records (Continued)

MOVE 20 TO RETURN-CODE GO TO RETURN-TO-SORT. IF COUNTER LESS THAN 100 MOVE 80 TO LEN-WK ADD 1 TO I-INCR MOVE 12 TO RETURN-CODE MOVE INSRT-REC TO WORK. GO TO RETURN-TO-SORT. IF COUNTER LESS THAN 200 MOVE 4 TO RETURN-CODE GO TO RETURN-TO-SORT. RETURN-TO-SORT. IF LAST-TIME MOVE 8 TO RETURN-CODE DISPLAY TOTAL. GOBACK.

Coding a C E15 Exit Routine


A C E15 exit program is indicated by the MODS control statement. An E15 exit cannot be coded in C when running Tape Sort. Like any other E15 exit routine, the C E15 exit routine is called each time a record is brought into Phase 1 of a sort or Phase 3 of a copy. SyncSort and the C exit communicate through arguments defined in the function header. For example, records are passed to the C routine by the address presented in the second argument in the function parameter list. No storage is reserved in the exit program because the records exist elsewhere. The C E15 exit routine can be written using either the C370 V2R1 compiler with the V2R2 C370 Library, the SAA AD/Cycle C370 V1R2 Compiler and Library or using the C/C++ for MVS/ESA V3R1.1 or higher Compiler and Library. When using the LE/370 run time library modules, it may be necessary to account for this additional storage by adjusting the b value of the Exit-Name parameter on the MODS statement.

Exit Communication
The parameter list structure required for passing fixed-length and variable-length records between the sort and the exit is detailed in the following section. The parameter names used in the examples are arbitrary but each definition is required. Complete sample programs showing the use of the argument lists are presented following the discussion of the exit interface.

Chapter 7. The Coding and Use of Exit Programs

7.19

Fixed-Length Records - Function Definition


int E15exit ( int* exit_status, struct_ru* record_up, struct_ins_rep* work, int* dummy1, int* dummy2, int* dummy3, int* dummy4, int* dummy5, int* comm_len, struct_ca* communication_area)

The following describes the parameters used in the preceding definition. exit_status This parameter points to a variable containing one of the following exit status codes: 00 First record. SyncSort uses this code to indicate the first call to the C exit and that the first record from SORTIN is in the record_up area. If the SORTIN is empty or does not exist, a 08 status will be passed the first time. Most records. This is used for all calls except the first one when there are records in the record_up area. After Code 00 has been issued, Code 04 is passed to the exit until there is no record for the sort to pass to the record_up area. All records passed. This indicates that the last SORTIN record has already been processed by the exit. Do not attempt to reference the record again. No more records will be passed to the exit routine. Note that if the SORTIN data set is empty or does not exist, 08 will be passed every time including the first time.

04

08

record_up

The record_up parameter contains a pointer to the record being passed to the E15 from the SORTIN. The struct_ru data type represents a structure that describes the fields within the SORTIN record. The work parameter contains a pointer to a work area that is to be used to hold an inserted or replaced record returned from the E15. The struct_ins_rep data type represents a structure that describes the fields within the inserted or replaced record. These parameters define unused place holders. They are used with variable-length E15 and E35 communication. Their definition here allows a common parameter list for fixed-length and variable-length C E15 and E35 exits.

work

dummy1 - dummy5

7.20

SyncSort for z/OS 1.2 Programmers Guide

comm_len

This parameter points to a variable that defines the communication area length. The communication_area parameter contains a pointer to the communication area. The struct_ca data type represents a structure that describes the fields in the communication area.

communication_area

Variable-Length Records - Function Definition


int E15exit ( int* exit_status, void* record_up, void* work, int* dummy1, int* dummy2, int* len_ru, int* len_wk, int* dummy3, int* comm_len, struct_ca* communication_area)

The following describes the parameters used in the preceding definition. exit_status This parameter points to a variable containing exit status codes. See the exit_status definition for a fixed-length C E15 exit for the code definitions. The record_up parameter contains a universal pointer to the record being passed to the E15 from the SORTIN. The void* pointer can be cast to point an appropriate structure to describe the record passed to the exit. This allows different record structures, as is common with variable-length records, to share a single pointer definition. The work parameter contains a "universal" pointer to a work area that is to be used to hold an inserted or replaced record returned from the E15. The void* pointer can be cast to point an appropriate structure to describe the work record. These parameters define unused place holders. They are used with C E35 communication. Their definition here allows a common parameter list for C E15 and E35 exits. This parameter points to a variable that defines the length of the SORTIN record passed to the E15. This is the length of the record referred to in the record_up parameter. This parameter points to a variable that defines the length of the record to be inserted or used as a replacement for the

record_up

work

dummy1 - dummy3

len_ru

len_wk

Chapter 7. The Coding and Use of Exit Programs

7.21

record_up record. This is the length of the record referred to in the work parameter. This field must be set by the exit when an insert or replace operation is performed. comm_len This parameter points to a variable that defines the communication area length. The communication_area parameter contains a pointer to the communication area. The struct_ca data type represents a structure that describes the fields in the communication area.

communication_area

RETURN-CODE Codes (Fixed and Variable-Length Records)


The RETURN statement is used to return control to SyncSort. It must indicate one of the following return values to indicate the action to be taken by SyncSort. 0 Accept this record. This instructs SyncSort to accept the (unaltered) record in the record_up area. Delete this record. SyncSort will delete the current record in the record_up area. Do not return to this exit. This instructs SyncSort to close the exit for the remainder of the sort application. This return code might be used at SORTIN end-of-file (exit_status code 08) to indicate that extra records will not be added at this point. If SORTIN is present, the current input record and all subsequent records will be processed by SyncSort. Insert a record. This instructs SyncSort to add the record in the work area to the input data set just ahead of the current record in the record_up area. When SyncSort returns control to the E15, the same record will be in the record_up area. The exit routine can then add another record from the work area or process the current record in record_up. When inserting a variablelength record, insure that its length is indicated in the len_wk parameter. Terminate SyncSort. SyncSort will end its program and return to the calling program or the Supervisor. SyncSort will issue a completion code of 16 to indicate that the sort was unsuccessful. Replace current record. SyncSort will replace the current record in the record_up area with the record in the work area. Be sure that the record in the work area is valid before passing it to SyncSort. When replacing a variable-length record, insure that its length is indicated in the len_wk parameter.

12

16

20

7.22

SyncSort for z/OS 1.2 Programmers Guide

How to Change a Record


To change the record in the record_up area, first move it to the work area. All changes are made to the work area copy, which replaces the record in record_up when the return value from the exit is 20.

Sample C E15, Fixed-Length Records

#define FIRST_TIME 0 #define MOST_TIME 4 #define LAST_TIME 8 #define ACCEPT_REC 0 #define DELETE_REC 4 #define END_EXIT 8 #define INSERT_REC 12 #define END_SORT 16 #define REPL_REC 20 typedef _Packed struct record { char name[6]; char code[4]; int serial_no; } t_ru; #include <stdio.h> #include <stdlib.h> #include <string.h> int SMPE15FB(int* exit_status,t_ru* record_up,t_ru* work,int* dummy1, int* dummy2,int* dummy3,int* dummy4,int* dummy5,int* comm_len, void* communication_area) { static counter=0; int icode,return_code; char * text1="CHANGE"; char * text2="INSERT"; if (counter > 10) {return_code=ACCEPT_REC; goto return_to_sort;} if (*exit_status == LAST_TIME) {return_code=END_EXIT; goto return_to_sort;}

Chapter 7. The Coding and Use of Exit Programs

7.23

Sample C E15, Fixed-Length Records (Continued)

sscanf(record_up->code,"%4d",&icode); if (icode==0) { return_code=DELETE_REC; goto return_to_sort;} if (icode==5) { strncpy(work->name,text2,6); sprintf(work->code,"%4d",icode+counter+8); work->serial_no=300; return_code=INSERT_REC; goto return_to_sort;} if (icode==6) { strncpy(work->name,text1,6); sprintf(work->code,"%4d",icode+1); work->serial_no=record_up->serial_no+200; return_code=REPL_REC; goto return_to_sort;} return_code=ACCEPT_REC; return_to_sort: counter++; if (*exit_status==LAST_TIME) { return_code=END_EXIT; printf("E15 total number of records handled:%d\n",counter); } return(return_code); }

7.24

SyncSort for z/OS 1.2 Programmers Guide

Sample C E15, Variable-Length Records

#define FIRST_TIME 0 #define MOST_TIME 4 #define LAST_TIME 8 #define ACCEPT_REC 0 #define DELETE_REC 4 #define END_EXIT 8 #define INSERT_REC 12 #define END_SORT 16 #define REPL_REC 20 #define MAX_RLEN 104 typedef _Packed struct record1 { char rec[6]; int incr; char address[MAX_RLEN-14]; } t_ru1; typedef _Packed struct record2 { char title[10]; int number; } t_ru2; #include <stdio.h> #include <stdlib.h> #include <strings.h> int SMPE15VB(int* exit_status,void* record_up,void* work,int* dummy1, int* dummy2,int* len_ru,int* len_wk,int* dummy3,int* comm_len, void* communication_area) { static counter=0,i_incr=0,i_number=0; int return_code; char *text1="CHANGE E15"; char *text2="INSERT E15"; t_ru1 * p_record1,*pwork1; t_ru2 * p_record2,*pwork2; p_record1 = (t_ru1 *)record_up; pwork1 = (t_ru1 *)work; p_record2 = (t_ru2 *)record_up; pwork2 = (t_ru2 *)work; if (*exit_status != FIRST_TIME) {counter++; return_code=ACCEPT_REC;}

Chapter 7. The Coding and Use of Exit Programs

7.25

Sample C E15, Variable-Length Records (Continued)

if (counter<50) { if (*len_ru == 14) { *len_wk = 14; i_number++; pwork2->number=i_number; strncpy(pwork2->title,text2,10); } else { *len_wk = 54; i_incr++; pwork1->incr=i_incr; strncpy(pwork1->rec,text2,6); } return_code=INSERT_REC; goto return_to_sort;} if (counter<75) { if (*len_ru == 14) { *len_wk = 14; pwork2->number=p_record2->number+1; strncpy(pwork2->title,text1,10); } else { *len_wk = 54; pwork1->incr=p_record1->incr+1; strncpy(pwork1->rec,text1,6); } return_code=REPL_REC; goto return_to_sort;} if (counter<100) { if (*len_ru == 14) { *len_wk = 14; i_number++; pwork2->number=i_number; strncpy(pwork2->title,text2,10); }

7.26

SyncSort for z/OS 1.2 Programmers Guide

Sample C E15, Variable-Length Records (Continued)

else { *len_wk = 80; i_incr++; pwork1->incr=i_incr; strncpy(pwork1->rec,text2,6); } return_code=INSERT_REC; goto return_to_sort;} if (counter<200) { return_code=DELETE_REC; goto return_to_sort;} return_to_sort: if (*exit_status==LAST_TIME) { return_code=END_EXIT; printf("E15 total number of records handled:%d\n",counter); } return(return_code); }

Exit E25 - Deleting, Changing, and Summarizing Records


SyncSort gives control to exit E25 each time it is about to place a record in a Phase 2 output sequence, except for the first record of that sequence. Because all or part of the input data set may skip this phase, it may be necessary to include an E35 to do the job of the E25 during Phase 3. If it is possible to use the SUM control statement in place of the exit, this is recommended. These constraints apply to the coding of an E25 exit routine: The exit may not add records. The exit may not change sort control fields. The exit may not destroy the contents of the parameter list.

SyncSort will place the address of a 2-word parameter list in Register 1 each time it passes control to the E25 routine. The first word, which is on a fullword boundary, will contain the address of the record about to leave Phase 2. The second word will contain the address of the record that has already passed into the output area. Note that the first byte of each word contains zeros.

Chapter 7. The Coding and Use of Exit Programs

7.27

PARAMETER LIST Word 1: Address of record leaving Phase 2 Word 2: Address of record already in output area Figure 203. Parameter List for E25 In order to change the record leaving Phase 2, the E25 exit program must first move it to a work area. (The record in the output area may be changed, but must be left where it is.) To sum two records, place the sum in the output area record and delete the record leaving Phase 2. After the record pair has been processed by the E25, a return code is placed into Register 15 and control returns to SyncSort.

Return Codes
0 Accept this record. To instruct SyncSort to accept the record leaving Phase 2, whether changed or unchanged, place return code 0 into Register 15. The (work area) address of the record to be accepted must be placed into Register 1. Delete this record. This tells SyncSort to delete the record about to leave Phase 2. It is not necessary to place the address of this record in Register 1. The next time SyncSort returns control to the exit program, the address of a new record will be in word 1 of the parameter list but word 2 will be unchanged. (This permits further summarization, for example.) Terminate SyncSort. SyncSort will end its program and return to the calling program or the supervisor. SyncSort will give the user a completion code of 16 to indicate that the sort was unsuccessful.

16

Exit E35 - Adding, Deleting, and Changing Records


When an output data set is available, the user may elect to incorporate this exit to add, delete or change records at the end of Phase 3. In the absence of an output data set, this exit has full responsibility for output processing and, under normal conditions, will delete every record passed by the sort. E35 record processing has these constraints: If a record is to be changed, it should first be moved to a work area. The exit program may not destroy the contents of the parameter list.

7.28

SyncSort for z/OS 1.2 Programmers Guide

A user exit may not take checkpoints.

Coding the E35 Exit Routine for an Invoked Sort/Merge/Copy


When SyncSort is initiated from an ATTACH, LINK or XCTL macro, there are two ways to include an E35 exit routine: (1) code the E35 exit routine in line with the invoking program and specify the address of its entry point in the appropriate entry of the calling programs parameter list; or (2) define the separately compiled routine in the MODS control statement. When the exit routine is coded in line with the invoking program, it must handle all output processing; SyncSort will ignore a SORTOUT DD statement and an OUTFIL control statement, if present.

The E35 Parameter List


This exit routine is given control each time SyncSort is about to place a record in the output area after the final merge. In passing control to the E35 exit routine, SyncSort places the address of a parameter list in Register 1. The parameter list starts at a fullword boundary and is 3 words long; the first byte of each word contains binary zeros. The first word contains the address of the record about to leave Phase 3; after the last record has been passed, this word will contain zeros. The second word contains the address of the record already in the output area; when the first record is passed, this word will contain zeros. The third word contains the user address constant. It contains either the last value set in it by an E15 exit routine or, if not modified by an E15 exit routine, the initial value from the user exit address constant provided in the invoking parameter list. If the value was obtained from the 24-bit invoking parameter list, it is limited to 24 bits with the high-order byte set to X'00'. If the user exit address constant was not provided or if SyncSort was JCL-invoked, it will contain binary zeros. This word may be changed by the E35 exit routine whenever it is entered, and it will remain the same on all subsequent entries to the E35 exit routine.

PARAMETER LIST Word 1: Address of record leaving Phase 3 Word 2: Address of record in output area Word 3: User address constant. Figure 204. Parameter List for E35

Return Codes
0 Accept this record. This instructs SyncSort to accept the record now leaving Phase 3. Place the (work area) address of this record in Register 1. This return code is used when selectively editing records for output; it passes the

Chapter 7. The Coding and Use of Exit Programs

7.29

(possibly altered) record back to the sort. The RECORD statement is required if this exit routine changes the maximum record length. 4 Delete this record. SyncSort will delete the record leaving Phase 3. There is no need to load the address of this record into Register 1. When SyncSort returns control to the E35, the first word of the parameter list (the address of the record leaving Phase 3) will refer to a new record, but the second word (the address of the output area record) will be unchanged. Disconnect E35. This instructs SyncSort to process any remaining records without showing them to the E35 exit. Register 1 is ignored for processing this return code. When this return code is used at end-of file (signalled by a zero address in the first word of the parameter list), it indicates that E35 is also finished and will not add additional records. When used before end-offile, it indicates that SyncSort should process the "current" record passed to the E35, and any subsequent records, as if there were no E35 present. Note that when SyncSort is not creating any output files (SORTOUT or SORTOFxx) and E35 is the only "output", SyncSort terminates immediately, since any subsequent records will never be seen. Note that if an XSUM data set was being created, it will only contain records generated prior to the return code of 8. Insert a record. This tells SyncSort to add a record just before the record is about to leave Phase 3. Load the address of the inserted record into Register 1. When SyncSort returns control to the E35 exit routine, the first word of the parameter list (the address of the record leaving Phase 3) will be unchanged, but the second word (the address of the output area record) will refer to the inserted record. The exit routine can then add another record or process the current one. Terminate SyncSort. This tells SyncSort to end its program and return to the calling program or the supervisor. SyncSort uses a completion code of 16 to indicate that the sort was unsuccessful.

12

16

Coding a COBOL E35 Exit Routine


A COBOL E35 exit program can be indicated through the EXEC statement PARM option (PARM='E35=COB'), the MODS control statement or the $ORTPARM DD statement. An E35 exit cannot be coded in COBOL when running Tape Sort. Like any other E35 exit routine, the COBOL E35 is called each time a record is brought out of Phase 3. Communication between SyncSort and the COBOL exit takes place in the LINKAGE SECTION of the COBOL program. For example, records are passed to the COBOL routine in the second definition (RECORD-UP) area of the LINKAGE SECTION. No storage is reserved in the exit program because the records exist elsewhere.

7.30

SyncSort for z/OS 1.2 Programmers Guide

If the COBOL exit routine uses any verb (EXHIBIT, DISPLAY, TRACE) which results in output to the SYSOUT DD statement, there is a potential conflict with SyncSorts use of this DD statement. It is therefore recommended that the user separate the output by using either SyncSorts MSGDD PARM option or the COBOL compilers SYSx parm.

The LINKAGE SECTION


The LINKAGE SECTION examples that follow show the parameters required for passing fixed-length and variable-length records to the sort. The data-names and conditional names used in the examples are arbitrary but each definition is required. The complete programs from which the examples are taken follow the discussion of the exit.

Example 1: Fixed-Length Records

LINKAGE SECTION. 01 EXIT-STATUS 88 FIRST-TIME 88 MOST-TIME 88 LAST-TIME 01 RECORD-UP. 05 RU WORK. 05 WK IN-BUF. 05 IB DUMMY1 DUMMY2 DUMMY3 DUMMY4 COMM-LEN COMMUNICATION-AREA. 05

PIC

9(8)

COMPUTATIONAL. VALUE 00. VALUE 04. VALUE 08.

PIC X(100).

01

PIC X(100).

01

PIC PIC PIC PIC PIC

X(100). X(4). X. X. X. COMPUTATIONAL.

01 01 01 01 01 01

PIC 9(4)

COMM-AREA OCCURS 1 TO 256 TIMES DEPENDING ON COMM-LEN PIC X.

The PICTURE and VALUE clauses for (1) the record passed from SyncSort, (2) the record WORK area, and (3) the record in the output buffer are application-specific.

Chapter 7. The Coding and Use of Exit Programs

7.31

For the first definition (EXIT-STATUS) specify PIC 9(8) COMPUTATIONAL. When using 88 levels to define exit status codes, specify values 00, 04, and 08. For the second definition (RECORD-UP) define the record leaving Phase 3. For the third definition (WORK) define the record that SyncSort is to put in the output data set. This is the "work" area. For the fourth definition (IN-BUF) define the record in the output data set. For the fifth definition define a dummy area with PIC X(4). For the sixth through the eighth definition define dummy areas. For the ninth definition (COMM-LEN) specify PIC 9(4) COMPUTATIONAL. This area defines the communication area length. For the tenth definition (COMMUNICATION-AREA) code an OCCURS clause DEPENDING ON data-name PIC X.

7.32

SyncSort for z/OS 1.2 Programmers Guide

Example 2: Variable-Length Records

LINKAGE SECTION. 01 EXIT-STATUS 88 FIRST-TIME 88 MOST-TIME 88 LAST-TIME 01 RECORD-UP. 05 RU

PIC

9(8) COMPUTATIONAL. VALUE 00. VALUE 04. VALUE 08.

OCCURS 1 TO 100 TIMES DEPENDING ON LEN-RU

PIC X.

01

WORK. 05 WK IN-BUF. 05 IB

OCCURS 1 TO 100 TIMES DEPENDING ON LEN-WK OCCURS 1 TO 100 TIMES DEPENDING ON LEN-IB PIC PIC PIC PIC PIC X(4) 9(8) 9(8) 9(8) 9(4)

PIC X.

01

PIC X.

01 01 01 01 01 01

DUMMY LEN-RU LEN-WK LEN-IB COMM-LEN

COMPUTATIONAL. COMPUTATIONAL. COMPUTATIONAL. COMPUTATIONAL.

COMMUNICATION-AREA. 05 COMM-AREA OCCURS 1 TO 256 TIMES DEPENDING ON COMM-LEN PIC X.

For the first definition (EXIT-STATUS) specify PIC 9(8) COMPUTATIONAL. When using 88 levels to define exit status codes, specify values 00, 04, and 08. For the second definition (RECORD-UP) code an OCCURS clause with the DEPENDING ON data-name option specifying (1) the minimum and maximum number of bytes of your variable-length records leaving Phase 3 (do not include 4 bytes for the RDW) and (2) DEPENDING ON data-name PIC X. Data-name is defined in the sixth definition in the LINKAGE SECTION. For the third definition (WORK) code an OCCURS clause with the DEPENDING ON data-name option specifying (1) the minimum and maximum number of bytes for variable-length records you will pass to SyncSort (do not include 4 bytes for the RDW) and (2) DEPENDING ON data-name PIC X. Data-name is defined as the seventh definition in the LINKAGE SECTION. This area is used for the work area.

Chapter 7. The Coding and Use of Exit Programs

7.33

For the fourth definition (IN-BUF) define records in the output area. Code an OCCURS clause with the DEPENDING ON data-name option specifying (1) the minimum and maximum number of bytes for variable-length records in the output data set (do not include 4-bytes for the RDW) and (2) DEPENDING ON data-name PIC X. Data-name is defined as the eighth definition in the LINKAGE SECTION. For the fifth definition define a dummy area with PIC X(4). For the sixth definition (LEN-RU) specify PIC 9(8) COMPUTATIONAL. SyncSort will pass the length of the record leaving Phase 3 in this area. For the seventh definition (LEN-WK) specify PIC 9(8) COMPUTATIONAL. The E35 routine passes SyncSort the length of the record in the work area in this section. For the eighth definition (LEN-IB) specify PIC 9(8) COMPUTATIONAL. SyncSort passes the length of the record in the output area in this section. For the ninth definition (COMM-LEN) specify PIC 9(4) COMPUTATIONAL. This area defines the communication area length. For the tenth definition (COMMUNICATION-AREA) code an OCCURS clause DEPENDING ON data-name PIC X.

The IDENTIFICATION, ENVIRONMENT, and DATA Divisions


As always, the COBOL program must contain the entries required by the compiler for these program divisions. Code the optional entries in these divisions according to the requirements of the application.

The WORKING-STORAGE SECTION


If the exit routine inserts records into the final merge and replaces records passed from SyncSort, the insertion record and the replacement record may be defined in this section. These records will be moved to the WORK area described in the LINKAGE SECTION, so be sure that the PICTURE clause or the OCCURS clause in the WORK area is correct for these records. This section may also define the return codes as 77-level data items. Alternatively, these codes can be specified as literals in the MOVE instruction. (MOVE literal to RETURNCODE.) Note that RETURN-CODE is the name of a predefined storage area in COBOL used to pass return codes to the sort; RETURN-CODE should not be defined in the exit routine.

The PROCEDURE DIVISION


Specify the USING option on the PROCEDURE DIVISION header. Each identifier specified after USING must be the same as those described in the 01-level of the LINKAGE

7.34

SyncSort for z/OS 1.2 Programmers Guide

SECTION. Taking for example the identifiers defined in the fixed-length record LINKAGE SECTION shown here, they would appear as: PROCEDURE DIVISION USING EXITSTATUS, RECORD-UP, WORK, IN-BUF, DUMMY1, DUMMY2, DUMMY3, DUMMY4, COM-LEN, COMMUNICATION-AREA. The GOBACK statement is used to return control to SyncSort. Do not use the EXIT statement as it will cause unpredictable results. Be sure that SyncSort receives a valid return code before the GOBACK statement is executed.

EXIT-STATUS Codes (Fixed and Variable-Length Records)


00 First Record. SyncSort uses this Code to indicate the first call to the COBOL exit and that the first record to leave Phase 3 is in the RECORDUP area. Most records. This is used for all calls except the first one when there are records in the RECORD-UP area. After Code 00 has been issued, Code 04 is passed to the exit until there is no record for the sort to pass to the RECORD-UP area. All records passed. This indicates that the last record has already been processed by the exit. Do not attempt to reference the record again. No more records will be passed to the exit routine. Note that if SyncSort is not passing any records to Phase 3, 08 will be passed every time including the first time.

04

08

RETURN-CODE Codes (Fixed and Variable-Length Records)


0 Accept this record. This instructs SyncSort to accept the (unaltered) record in the RECORD-UP area. Delete this record. SyncSort will delete the current record in the RECORDUP area. Disconnect E35. This instructs SyncSort to process any remaining records without showing them to the E35 exit. Register 1 is ignored for processing this return code. When this return code is used at end-of-file (signalled by EXIT-STATUS LAST-TIME), it indicates that the E35 is also finished and will not add additional records. When used before end-of-file, it indicates that SyncSort should process the "current" record passed to the E35, and any subsequent records, as if there were no E35 present. Note that when SyncSort is not creating any output files (SORTOUT or SORTOFxx) and E35 is the only "output," SyncSort terminates immediately, since any subsequent records will never be seen. Also note that if an XSUM data set was being created, it will only contain records generated prior to the return code of 8.

Chapter 7. The Coding and Use of Exit Programs

7.35

12

Insert a record. This instructs SyncSort to add the record in the WORK area to the input data set just ahead of the current record in the RECORD-UP area. When SyncSort returns control to the E35, the same record will be in the RECORD-UP area. The exit routine can then add another record from the WORK area or process the current record in RECORD-UP. Terminate SyncSort. SyncSort will terminate and return to the calling program or the Supervisor. SyncSort will issue a completion code of 16 to indicate that the sort was unsuccessful. Replace current record. SyncSort will replace the current record in the RECORD-UP area with the record in the WORK area. Be sure that the record in the WORK area is valid before passing it to SyncSort.

16

20

To Change a Record
In order to change the record in the RECORD-UP area, first move it to the WORK area. Make the changes there and then pass return code 20 in RETURN-CODE. The altered record in the WORK area will replace the record in RECORD-UP.

7.36

SyncSort for z/OS 1.2 Programmers Guide

Sample COBOL E35, Fixed-Length Records

IDENTIFICATION DIVISION. PROGRAM-ID. E35FL101. ENVIRONMENT DIVISION. CONFIGURATION SECTION. SOURCE-COMPUTER. IBM-390. OBJECT-COMPUTER. IBM-390. INPUT-OUTPUT SECTION. FILE-CONTROL. I-O-CONTROL. DATA DIVISION. FILE SECTION. WORKING-STORAGE SECTION. 01 EVEN-FLAG 01 USER-RETURN-CODE 88 ACCEPT-REC 88 DELETE-REC 88 END-EXIT 88 INSERT-REC 88 END-SORT 88 REPL-REC CHANGE-REC. 05 C-REC 05 C-INCR 05 C-BLANK

PIC 9(2) PIC 9(8)

VALUE ZERO. COMPUTATIONAL. VALUE 0. VALUE 4. VALUE 8. VALUE 12. VALUE 16. VALUE 20.

01

PIC X(6) PIC 9(4) PIC X(90)

VALUE 'CHANGE'. VALUE ZERO. VALUE SPACES.

01 INSRT-REC. 05 I-REC 05 I-INCR 05 I-BLANK 01

PIC X(6) PIC 9(4) PIC X(90)

VALUE 'INSERT'. VALUE ZERO. VALUE SPACES.

TOTAL. 05 BLANKS PIC X(10) 05 TITL PIC X(25) VALUE 'TOTAL RECORDS HANDLED'. 05 COUNTER PIC 9(8)

VALUE 'E35'.

VALUE 0

Chapter 7. The Coding and Use of Exit Programs

7.37

Sample COBOL E35, Fixed-Length Records (Continued)

LINKAGE SECTION. 01 EXIT-STATUS 88 FIRST-TIME 88 MOST-TIME 88 LAST-TIME 01 01 01 01 RECORD-UP. 05 RU WORK. 05 WK IN-BUF. 05 IB DUMMY1

PIC 9(8)

COMPUTATIONAL. VALUE 00. VALUE 04. VALUE 08.

PIC X(100). PIC X(100). PIC X(100). PIC X(4).

PROCEDURE DIVISION USING EXIT-STATUS, RECORD-UP, WORK, IN-BUF, DUMMY. IF NOT FIRST-TIME ADD 1 TO COUNTER MOVE 0 TO RETURN-CODE. IF COUNTER LESS THAN 50 ADD 1 TO I-INCR MOVE INSRT-REC TO WORK MOVE 12 TO RETURN-CODE GO TO RETURN-TO-SORT. IF COUNTER LESS THAN 75 ADD 1 TO C-INCR MOVE CHANGE-REC TO WORK MOVE 20 TO RETURN-CODE GO TO RETURN-TO-SORT.

7.38

SyncSort for z/OS 1.2 Programmers Guide

Sample COBOL E35, Fixed-Length Records (Continued)

IF COUNTER LESS THAN 100 ADD 1 TO I-INCR MOVE INSRT-REC TO WORK MOVE 12 TO RETURN-CODE GO TO RETURN-TO-SORT. IF COUNTER LESS THAN 200 MOVE 4 TO RETURN-CODE GO TO RETURN-TO-SORT. RETURN-TO-SORT. IF LAST-TIME MOVE 8 TO RETURN-CODE DISPLAY TOTAL. GOBACK.

Chapter 7. The Coding and Use of Exit Programs

7.39

Sample COBOL E35, Variable-Length Records

IDENTIFICATION DIVISION. PROGRAM-ID. E35VL101. ENVIRONMENT DIVISION. CONFIGURATION SECTION. SOURCE-COMPUTER. IBM-390. OBJECT-COMPUTER. IBM-390. INPUT-OUTPUT SECTION. FILE-CONTROL. I-O-CONTROL. DATA DIVISION. FILE SECTION. WORKING-STORAGE SECTION. 01 EVEN-FLAG 01 USER-RETURN-CODE 88 ACCEPT-REC 88 DELETE-REC 88 END-EXIT 88 INSERT-REC 88 END-SORT 88 REPL-REC CHANGE-REC. 05 C-REC 05 C-INCR 05 C-BLANK

PIC 9(2) VALUE ZERO. PIC 9(8) COMPUTATIONAL. 0. 4. 8. 12. 16. 20.

VALUE VALUE VALUE VALUE VALUE VALUE

01

PIC X(6) VALUE 'CHANGE'. PIC 9(4) VALUE ZERO. PIC X(90) VALUE SPACES.

01 INSRT-REC. 05 I-REC 05 I-INCR 05 I-BLANK 01

PIC X(6) VALUE 'INSERT'. PIC X(4) VALUE ZERO. PIC X(90) VALUE SPACES.

TOTAL. 05 BLANKS PIC X(10) VALUE ' E35'. 05 TITL PIC X(25) VALUE 'TOTAL RECORDS HANDLED'. 05 COUNTER PIC 9(8) VALUE 0.

7.40

SyncSort for z/OS 1.2 Programmers Guide

Sample COBOL E35, Variable-Length Records (Continued)

LINKAGE SECTION. 01 EXIT-STATUS 88 FIRST-TIME 88 MOST-TIME 88 LAST-TIME 01 RECORD-UP. 05 RU OCCURS 1 TO 100 TIMES DEPENDING ON LEN-RU WORK. 05 WK OCCURS 1 TO 100 TIMES DEPENDING ON LEN-WK IN-BUF. 05 IB OCCURS 1 TO 100 TIMES DEPENDING ON LEN-IB DUMMY PIC X(4). LEN-RU LEN-WK LEN-IB

PIC 9(8)

COMPUTATIONAL. VALUE 00. VALUE 04. VALUE 08.

PIC X.

01

PIC X.

01

PIC X.

01 01 01 01

PIC 9(8) PIC 9(8) PIC 9(8)

COMPUTATIONAL. COMPUTATIONAL. COMPUTATIONAL.

Chapter 7. The Coding and Use of Exit Programs

7.41

Sample COBOL E35, Variable-Length Records (Continued)

PROCEDURE DIVISION USING EXIT-STATUS, RECORD-UP, WORK, IN-BUF, DUMMY, LEN-RU, LEN-WK, LEN-IB.

IF NOT FIRST-TIME ADD 1 TO COUNTER MOVE 0 TO RETURN-CODE. IF COUNTER LESS THAN 50 MOVE 54 TO LEN-WK ADD 1 TO I-INCR MOVE INSRT-REC TO WORK MOVE 12 TO RETURN-CODE GO TO RETURN-TO-SORT. IF COUNTER LESS THAN 75 MOVE 44 TO LEN-WK ADD 1 TO C-INCR MOVE CHANGE-REC TO WORK MOVE 20 TO RETURN-CODE GO TO RETURN-TO-SORT. IF COUNTER LESS THAN 100 MOVE 80 TO LEN-WK ADD 1 TO I-INCR MOVE INSRT-REC TO WORK MOVE 12 TO RETURN-CODE GO TO RETURN-TO-SORT. IF COUNTER LESS THAN 200 MOVE 4 TO RETURN-CODE GO TO RETURN-TO-SORT. RETURN-TO-SORT. IF LAST-TIME MOVE 8 TO RETURN-CODE DISPLAY TOTAL. GOBACK.

7.42

SyncSort for z/OS 1.2 Programmers Guide

Coding a C E35 Exit Routine


A C E35 exit program is indicated by the MODS control statement. An E35 exit cannot be coded in C when running Tape Sort. Like any other E35 exit routine, the C E35 exit routine is called each time a record is brought out of Phase 3. Communication between SyncSort and the C exit takes place through arguments defined in the function header. For example, records are passed to the C routine by an address presented in the second argument in the function parameter list. No storage is reserved in the exit program because the records exist elsewhere. The C E35 exit routine can be written using either the C370 V2R1 compiler with the V2R2 C370 Library, the SAA AD/Cycle C370 V1R2 Compiler and Library or the C/C++ for MVS/ ESA V3R1.1 Compiler and Library. When using the LE/370 run time library modules, it may be necessary to account for this additional storage by adjusting the b value of the ExitName parameter on the MODS statement.

Exit Communication
The parameter list structure required for passing fixed-length and variable-length records between the sort and the exit is detailed in the following section. The parameter names used in the examples are arbitrary but each definition is required. Complete sample programs showing the use of the argument lists are presented following the discussion of the exit interface.

Fixed-Length Records - Function Definition


int E35exit ( int* exit_status, struct_ru* record_up, struct_ins_rep* work, struct_in_buf* in_buf, int* dummy1, int* dummy2, int* dummy3, int* dummy4, int* comm_len, struct_ca* communication_area)

The following describes the parameters used in the preceding definition. exit_status This parameter points to a variable containing one of the following exit status codes: 00 First record. SyncSort uses this Code to indicate the first call to the C exit and that the first record to leave Phase 3 is in the record_up area. If there are no records

Chapter 7. The Coding and Use of Exit Programs

7.43

to pass to the exit, a 08 status will be passed to the exit on the first call. 04 Most records. This is used for all calls except the first one when there are records in the record_up area. After Code 00 has been issued, Code 04 is passed to the exit until there is no record for the sort to pass to the record_up area. All records passed. This indicates that the last record has already been processed by the exit. Do not attempt to reference the record again. No more records will be passed to the exit routine. Note that if SyncSort is not passing any records to Phase 3, 08 will be passed every time including the first time.

08

record_up

The record_up parameter contains a pointer to the record leaving Phase 3. The struct_ru data type represents a structure that describes the fields within the record. The work parameter contains a pointer to a work area that is to be used to hold an inserted or replaced record returned from the E35. The struct_ins_rep data type represents a structure that describes the fields within the inserted or replaced record. The in_buf parameter contains a pointer to the record that SyncSort is to put in the output data set. Until a record has been accepted or inserted, this pointer will be null. A record at this address can be modified if required. These parameters define unused place holders. They are used with variable-length C E35 communication. Their definition here allows a common parameter list for fixed and variablelength C E15 and E35 exits. This parameter points to a variable that defines the communication area length. The communication_area parameter contains a pointer to the communication area. The struct_ca data type represents a structure that describes the fields in the communication area.

work

in_buf

dummy1 - dummy4

comm_len

communication_area

7.44

SyncSort for z/OS 1.2 Programmers Guide

Variable-Length Records - Function Definition


int E35exit ( int* exit_status, void* record_up, void* work, void* in_buf, int* dummy1, int* len_ru, int* len_wk, int* len_ib, int* comm_len, struct_ca* communication_area)

The following describes the parameters used in the preceding definition. exit_status This parameter points to a variable containing exit status codes. See the exit_status definition for a fixed-length C E35 exit for the code definitions. The record_up parameter contains a universal pointer to the record leaving Phase 3. The void* pointer can be cast to point an appropriate structure to describe the record passed to the exit. This allows different record structures, as is common with variable-length records, to share a universal pointer. The work parameter contains a "universal" pointer to a work area that is to be used to hold an inserted or replaced record returned from the E35. The void* pointer can be cast to point an appropriate structure to describe the work record. The in_buf parameter contains a "universal" pointer to the record that SyncSort is to put in the output data set. Until a record has been accepted or inserted, this pointer will be null. The void* pointer can be cast to point an appropriate structure to describe the work record. This parameter defines an unused place holder. This parameter points to a variable that defines the length of the record leaving Phase 3. This is the length of the record referred to in the record_up parameter. This parameter points to a variable that defines the length of the record to be inserted or used as a replacement for the record_up record. This is the length of the record referred to in the work parameter.

record_up

work

in_buf

dummy1 len_ru

len_wk

Chapter 7. The Coding and Use of Exit Programs

7.45

len_ib

This parameter points to a variable that defines the length of the record that SyncSort is to put in the output data set. This is the length of the record referred to in the in_buf parameter. This parameter points to a variable that defines the communication area length. The communication_area parameter contains a pointer to the communication area. The struct_ca data type represents a structure that describes the fields in the communication area.

comm_len

communication_area

RETURN-CODE Codes (Fixed and Variable-Length Records)


0 Accept this record. This instructs SyncSort to accept the (unaltered) record in the record_up area. Delete this record. SyncSort will delete the current record in the record_up area. Disconnect E35. This instructs SyncSort to process any remaining records without showing them to the E35 exit. When this return code is used at end-of-file (signalled by exit_status 08), it indicates that the E35 is also finished and will not add additional records. When used before end-of-file, it indicates that SyncSort should process the "current" record passed to the E35, and any subsequent records, as if there were no E35 present. Note that when SyncSort is not creating any output files (SORTOUT or SORTOFxx) and E35 is the only "output," SyncSort terminates immediately, since any subsequent records will never be seen. Insert a record. This instructs SyncSort to add the record in the work area to the input data set just ahead of the current record in the record_up area. When SyncSort returns control to the E35, the same record will be in the record_up area. The exit routine can then add another record from the work area or process the current record in record_up. Terminate SyncSort. SyncSort will terminate and return to the calling program or the Supervisor. SyncSort will issue a completion code of 16 to indicate that the sort was unsuccessful. Replace current record. SyncSort will replace the current record in the record_up area with the record in the work area. Be sure that the record in the work area is valid before passing it to SyncSort.

12

16

20

Change a Record
In order to change the record in the record_up area, first move it to the provided work area. Make the changes there and then pass return code 20. The altered record in the work area will replace the record in record_up.

7.46

SyncSort for z/OS 1.2 Programmers Guide

Sample C E35, Fixed-Length Records

#define FIRST_TIME 0 #define MOST_TIME 4 #define LAST_TIME 8 #define ACCEPT_REC 0 #define DELETE_REC 4 #define END_EXIT 8 #define INSERT_REC 12 #define END_SORT 16 #define REPL_REC 20 #include <decimal.h> typedef _Packed struct record { char rec[6]; decimal(7,0) incr; char address[90]; } t_ru; int counter,i_incr; #include <stdio.h> #include <stdlib.h> #include <string.h> int SMPE35FB(int* exit_status,t_ru* record_up,t_ru* work,t_ru* in_buf, int* dummy1,int* dummy2,int* dummy3,int* dummy4,int* comm_len, void* communication_area) { int return_code; char *text1="CHANGE"; char *text2="INSERT"; if (*exit_status != FIRST_TIME) {counter++; return_code=ACCEPT_REC; }

Chapter 7. The Coding and Use of Exit Programs

7.47

Sample C E35, Fixed-Length Records (Continued)

if (counter<50) { i_incr++; work->incr=i_incr; strncpy(work->rec,text2,6); return_code=INSERT_REC; goto return_to_sort;} if (counter<75) { work->incr=record_up->incr+1d; strncpy(work->rec,text1,6); return_code=REPL_REC; goto return_to_sort;} if (counter<100) { i_incr++; work->incr=i_incr; strncpy(work->rec,text2,6); return_code=INSERT_REC; goto return_to_sort;} if (counter<200) { return_code=DELETE_REC; goto return_to_sort;} return_to_sort: if (*exit_status==LAST_TIME) { return_code=END_EXIT; printf("E35 total number of records handled:%d\n",counter); } return(return_code); }

7.48

SyncSort for z/OS 1.2 Programmers Guide

Sample C E35, Variable-Length Records

#define FIRST_TIME 0 #define MOST_TIME 4 #define LAST_TIME 8 #define ACCEPT_REC 0 #define DELETE_REC 4 #define END_EXIT 8 #define INSERT_REC 12 #define END_SORT 16 #define REPL_REC 20 #define MAX_RLEN 104 typedef _Packed struct record1 { char rec[6]; int incr; char address[MAX_RLEN-14]; } t_ru1; typedef _Packed struct record2 { char title[10]; int number; } t_ru2; int counter,i_incr,i_number; #include <stdio.h> #include <stdlib.h> #include <string.h> int SMPE35VB(int* exit_status,void* record_up,void* work,void* in_buf, int* dummy,int* len_ru,int* len_wk,int* len_ib,int* comm_len, void* communication_area) {

Chapter 7. The Coding and Use of Exit Programs

7.49

Sample C E35, Variable-Length Records (Continued)

int return_code; char *text1="CHANGE E35"; char *text2="INSERT E35"; t_ru1 * p_record1,*pwork1; t_ru2 * p_record2,*pwork2; p_record1 = (t_ru1 *)record_up; pwork1=(t_ru1 *)work; p_record2 = (t_ru2 *)record_up; pwork2=(t_ru2 *)work; if (* exit_status != FIRST_TIME) {counter++; return_code=ACCEPT_REC;} if (counter<50) { if (*len_ru == 14) { *len_wk = 14; i_number++; pwork2->number=i_number; strncpy(pwork2->title,text2,10); } else { *len_wk = 54; i_incr++; pwork1->incr=i_incr; strncpy(pwork1->rec,text2,6); } return_code=INSERT_REC; goto return_to_sort;} if (counter<75) { if (*len_ru == 14) { *len_wk = 14; pwork2->number=p_record2->number+1; strncpy(pwork2->title,text1,10); } else { *len_wk = 54; pwork1->incr=p_record1->incr+1; strncpy(pwork1->rec,text1,6); } return_code=REPL_REC; goto return_to_sort;}

7.50

SyncSort for z/OS 1.2 Programmers Guide

Sample C E35, Variable-Length Records (Continued)

if (counter<100) { if (*len_ru == 14) { *len_wk = 14; i_number++; pwork2->number=i_number; strncpy(pwork2->title,text2,10); } else { *len_wk = 80; i_incr++; pwork1->incr=i_incr; strncpy(pwork1->rec,text2,6); } return_code=INSERT_REC; goto return_to_sort;} if (counter<200) { return_code=DELETE_REC; goto return_to_sort;} return_to_sort: if (*exit_status==LAST_TIME) { return_code=END_EXIT; printf("E35 total number of records handled:%d\n",counter); } return(return_code); }

Exit E16-Taking Action on Insufficient Intermediate Storage


Exit E16 is given control in the event that the input data set is unable to fit into intermediate storage. There is no parameter list. The E16 return code tells SyncSort how to respond to the insufficient SORTWK problem.

Return Codes
0 Sort present records only. This instructs SyncSort to process only those records presently contained on the intermediate storage devices. The sort will receive message WER054I RCD IN xxxxxxxx, OUT yyyyyyyy if the data is read from SORTIN directly, or WER055I INSERT xxxxxxxx, DELETE yyyyyyyy if the data receives input exit (E14 or E15) or INCLUDE/OMIT processing. The messages RCD IN or INSERT xxxxxxxx figure indicates how many records have been sorted. For a sort with no

Chapter 7. The Coding and Use of Exit Programs

7.51

exits or INCLUDE/OMIT processing, the remaining records may be sorted by running another job using the SKIPREC=n parameter on the SORT control statement, skipping the xxxxxxxx number of records. The new sort will start just where the last one left off. The final output is obtained by running a MERGE with the two SORTOUT data sets. 4 Try to sort all records. This tells SyncSort to continue to read in records from the input data set. If there are very few records left, the sort may complete successfully. If there are too many records to continue the sort, SyncSort will terminate with a SORT CAPACITY EXCEEDED message. Terminate SyncSort. SyncSort will terminate immediately with a SORT CAPACITY EXCEEDED message.

12

Exits E17, E27, and E37 - Closing Data Sets


These exits are unusual in that they are entered only once, at the end of their associated phase. Because of this, they may be efficiently used to clean up after other exit routines (e.g., to close data sets). There are no parameter lists or return codes for these exits.

Exits E18, E38, and E39 - Checking Labels, Processing Read or Write Errors, End-of-File Routines, Special VSAM Processing
These exits are mainly used for I/O error recovery routines. However, they may also be used to check labels, to do end-of-file processing, and to provide various information to the VSAM access method.

Exit E18 and E38 Programs


Exit E18 is only used for sorts and exit E38 only for merges or copies. Each exit is entered exactly once, at the start of SORTIN processing. At this time, SyncSort checks Register 1 for the address of a user parameter list specifying the various open and error exit routines the user wishes SyncSort to include. SyncSort will then enter these routines at the appropriate times during execution. Because use to these exits forces the use of BSAM for the input file(s), performance may be adversely affected. The format of the parameter list is given below. More information on the DCB fields can be found in the appropriate IBM publication.

7.52

SyncSort for z/OS 1.2 Programmers Guide

Byte 1 01 02 03 04 00

Byte 2

Byte 3 SYNAD field EXLST field

Byte 4

00

00 EODAD field

EROPT code

00 Table 34.

00 Parameter List for E18 and E38

00

The parameter list must begin on a fullword boundary and consist of an integral number of words. With the exception of the required fullword of zeros used to indicate the end of the parameter list, entries are optional. The first byte of each word identifies the parameter: SYNAD field Indicated by 01 in byte 1. The SYNAD field contains the address of a synchronous read error routine, assembled as part of the exit program. Note that you may not use Register 13 as a save area pointer on entry to your routine. You must either provide your own save area or use the SYNADAF macro instruction. Indicated by 02 in byte 1. The EXLST field contains the address of a list of pointers to user routines that perform operations such as label checking. Note that in the event that the list contains a DCB-exit entry, it will not be entered during concatenated SORTIN processing. Indicated by 03 in byte 1. Bytes 2 and 3 contain zeros, byte 4 the EROPT code. This code tells SyncSort what action to take if it discovers an uncorrectable read error on a non-VSAM input file. X'00' Follow the EROPT code in the DCB parameter of the DD statement that describes the data set containing the error. Terminate the program. Skip the block containing the error. Accept the block containing the error.

EXLST field

EROPT code

X '20' X'40' X'80' EODAD field

Indicated by 04 in byte 1. The EODAD field contains the address of an end-of-file routine. It can only be used with an E18 exit.

Chapter 7. The Coding and Use of Exit Programs

7.53

VSAM Input to E18 and E38


With VSAM input, these exits can be used to pass the addresses of various VSAM exits or to insert passwords into VSAM input ACBs. When control is returned to the sort, Register 1 must contain the address of a parameter list: X'05' X'06' 3 byte address of VSAM exit list 3-byte address of password list

F'0' Fullword of zeros Table 35. Sample VSAM Parameter List for E18 and E38

If both address entries are present, they may be in either order. Only one need be present. (QSAM parameters will be ignored.) The password list referenced in the parameter list is found in the exit routine and is formatted as follows: 2 bytes on a halfword boundary: Number n of entries in list Followed by n 16-byte entries: 8-byte DDname 8-byte Password The exit routine must not alter this list. The sort may destroy the last byte of the DD name field. The exit list is built using the VSAM EXLST macro, which provides the addresses of the VSAM exit routines. VSAM branches directly to the routines which must return to VSAM via the address in Register 14. To do EODAD processing with E38, write a LERAD exit and check for X'04' in the FDBK field of the RPL: this indicates input EOD. This field is needed by the merge, so it should not be altered when returning to VSAM. The following example shows how to code the return to the sort.

7.54

SyncSort for z/OS 1.2 Programmers Guide

E18

PARMLST

VSAMEXL PWDLST

SYNAD LERAD BSAMERR EXLST BSAMEOD

ENTRY . . . LA ST LM BR CNOP DC DC DC DC DC DC DC DC DC DC DC DC DC . . . EXLST DC DC DC DC DC ... ... ... ... ...

E18

1,PARMLST 1,24(13) R13 points to sort's save area 14,12,12(13) 14 0,4 X'01' AL3(BSAMERR) X'02' AL3(EXLST) X'03' X'000080' EROPT code X'04' AL3 (BSAMEOD) X'05' AL3 (VSAMEXL) X'06' AL3 (PWDLST) A(0)

SYNAD=SYNAD,LERAD=LERAD H'2' CL8'SORTIN' SORTIN ddname CL8'INPASS' SORTIN password CL8'SORTOUT' SORTOUT ddname CL8'OUTPASS' SORTOUT password VSAM synch error rtn VSAM logic error rtn BSAM error rtn EXLST address list BSAM end of data rtn Figure 205. Sample E18 Program

Exit E39 Programs


Exit E39 is used mainly for SORTOUT write error routines. The exit is entered once at the beginning of merge or copy processing or the start of sort Phase 3. At this time SyncSort checks Register 1 for the address of a user parameter list specifying the various routines

Chapter 7. The Coding and Use of Exit Programs

7.55

the user wishes SyncSort to include. SyncSort will then enter these routines at the appropriate times during execution. The use of an E39 exit forces the use of BSAM on the output file; this may degrade performance somewhat. The format of the parameter list is given below. Byte 1 01 02 00 00 Table 36. Byte 2 Byte 3 SYNAD field EXLST field 00 Parameter List for E39 00 Byte 4

The parameter list must begin on a fullword boundary and consist of an integral number of words. With the exception of the required fullword of zeros used to indicate the end of the parameter list, entries are optional. The first byte of each word identifies the parameter: SYNAD field Indicated by 01 in byte 1. The SYNAD field contains the address of a synchronous write error routine, assembled as part of the exit program. Note that you may not use Register 13 as a save area pointer on entry to your routine. You must either provide your own save area or use the SYNADAF macro instruction. EXLST field Indicated by 02 in byte 1. The EXLST field contains the address of a list of pointers to user routines that perform operations such as label checking. If the EXLST field is specified, CHECKPOINT processing will not be performed by SyncSort. Exit E39 may be used to supply a VSAM exit list or password list for the output file in the same manner as described for exits E18 and E38. Note that unlike E18 there is no EODAD field with this exit.

Exit E61 - Modifying the Collating Process


Exit 61 is used to alter the collating of all control fields specified as having an o (order) value of E in the SORT/MERGE control statement. Note that an E61 exit routine is called in Phase 1 for sort applications and in Phase 3 for merge applications. Each time SyncSort encounters an order E control field, it moves a copy of the control field to a work area and passes the copys address to the exit routine. Thus, the E61 exit program processes a control field image while leaving the original control field intact. An order E control field is collated in ascending order according to its f (format) code and its E61 image. In order to code an effective E61 routine, the user must be familiar with the standard data formats used by the operating system. For all order E control fields except BInary fields, the number of bytes in the control field image will be the number specified as the l (length) value on the SORT/MERGE control

7.56

SyncSort for z/OS 1.2 Programmers Guide

statement. BInary fields are left and right padded with zeros to the nearest byte boundary. For example, a control field designated as 5.3,1.4,BI,E receives three bits of padding on the left, one on the right, producing an image 2 bytes long. An E61 exit can process only the first 256 bytes of the control field image in a single pass. If a control field image is more than 256 bytes long, the exit will be entered more than once for that control field. If AC is specified as the format of a control field on the SORT or MERGE statement, SyncSort will translate the field to ASCII before the E61 routine is given control. In order to use an E61 routine to modify what would be an AC control field, specify the field as CH in the SORT or MERGE statement and translate the image to ASCII after it is altered by the E61 exit routine. There is no advantage to coding an E61 exit if the ALTSEQ control statement can provide the needed collating modification. ALTSEQ changes the installations alternate collating sequence, used for all control fields specified with the format code AQ. An E61 exit cannot be used with locale processing (LOCALE option enabled).

The Parameter List


Each time your routine is executed, SyncSort will place the address of a three-word parameter list in Register 1. The parameter list will be on a fullword boundary. The first word contains the number of the control field within the record in byte 4. The second word contains the address of the control field in the work area in bytes 2, 3, and 4. The third word contains the length of the control field in bytes 3 and 4. All values are given in hexadecimal and the unused bytes are filled with zeros. Byte 1 00 00 00 00 Table 37. Byte 2 00 Byte 3 00 Byte 4 Number of control field

Address of control field in work area Length of control field Parameter List for E61

Lengthening a Control Field Image


The length of the control field image is completely determined by the length and format code of the control field. Therefore, in order to provide a 12-byte PD image of 5 bytes from the original record, it is necessary for the SORT/MERGE control statement to reference a 12-byte PD control field that contains the 5 desired bytes. The extra 7 bytes are used to contain the "lengthened" image.

Chapter 7. The Coding and Use of Exit Programs

7.57

Shortening a Control Field Image


The length of the control field image is completely determined by the length and format code of the control field. To shorten a control field image, specify the full length of the original control field as the l (length) value in the SORT/MERGE control statement. Then shorten each image by the same number of bytes and pad it uniformly to the length of the original field. Be sure to pad each control field image with the same leading or trailing character, and replace data in the control field image with the same type of data as that in the actual control field.

Reversing a Collating Sequence


Every order E control field is collated according to its image and format code, in ascending order. To collate the field in apparent descending order, complement the control field image according to its format code before returning control to SyncSort. For a BI or CH field, for example, complement the image with hexadecimal FFs before returning control to the sort.

Coding REXX Exits


The exit routines E15 and E35 can be coded in REXX.

REXX Variables Provided by SyncSort for z/OS


SyncSort for z/OS provides a number of special REXX variables to facilitate the development of REXX exits. These variables offer a simple, efficient means of establishing communication between the exit and the sort/merge. To load these variables, the following command must be used when the exit is called. ADDRESS 'SYNCREXX' 'GIVE' When the exit completes its work, the exit should use the following sequence of commands to return the variables to SyncSort for z/OS. ADDRESS 'SYNCREXX' 'TAKE' RETURN The following table describes the special REXX variables.

7.58

SyncSort for z/OS 1.2 Programmers Guide

Variable SYRECORD

Function When the exit is entered, SYRECORD contains the current data record. The exit can accept the record, modify it or add a new record; SYACTION should be set accordingly. If SYRECORD is null, then SyncSort for z/OS has no data remaining. When this happens, the exit can either CLOSE or continue to INSERT new records.

SYACTION

This variable must be set before the exit returns control to SyncSort for z/OS. It describes the disposition of the current record. Possible values for SYACTION are as follows: ACCEPT: REPLACE: Retain the current record with no modification. Replace the current record with the contents of the SYRECORD. Delete the current record. Insert the contents of the SYRECORD before the current record. Do not return to the exit. Terminate SyncSort for z/OS.

DELETE: INSERT:

CLOSE: ABEND:

If an E15 is providing all the input (SORTIN not present), the only valid values for SYACTION are INSERT, CLOSE or ABEND. SYEXITYP SYGBLN1... ...SYGBLN8 This variable will automatically be set to E15 or E35, depending on which type of exit is being called. These eight special variables are global variables. The user may set these to any value provided that the value does not exceed 15 characters in length. SyncSort for z/OS will insure that these variables are preserved across calls to the exit. This is an additional global variable. The user may set this to any value, provided the string does not exceed 1024 characters in length. SyncSort for z/OS will insure that this variable is preserved across calls to the exit. Table 38. REXX Variables Provided by SyncSort for z/OS

SYGBLSTR

Sample REXX Exit


The following example illustrates a REXX exit that will count the number of records that are passed to the exit:

Chapter 7. The Coding and Use of Exit Programs

7.59

address 'SYNCREXX' 'GIVE' if sygbln1='SYGBLN1' then sygbln1=0 if LENGTH(syrecord) > 0 then do syaction='REPLACE' sygbln1=sygbln1 + 1 end else do syaction='CLOSE' say 'REXX' syexityp 'counted' sygbln1 'records' end address 'SYNCREXX' 'TAKE' return Figure 206. Sample REXX Exit Code

7.60

SyncSort for z/OS 1.2 Programmers Guide

Chapter 8. The Flow of the Sort

This chapter briefly outlines the flow of control in the standard Disk Sort, incore sort, merge and copy. It describes the order in which SyncSort will process and act on the PARMs, control statements and exit routines provided by the user. Note that all executions begin with Phase 0 processing and that a given SyncSort execution will skip steps where appropriate (e.g., will skip a Variable-length record sampling step if sorting fixed-length records or HISTOGRM length values are supplied). No attempt has been made to indicate which steps are required of all Disk Sorts, incore sorts, etc., or to indicate the nature or timing of any abend processing.

Phase 0 Process PARMs, merging EXEC and $ORTPARM PARM specifications. The EXEC statement/invoking programs parameter list overrides the installation defaults. $ORTPARM overrides the EXEC statement/invoking programs parameter list. Process control statements (from the $ORTPARM DD statement and either the SYSIN DD statement or the invoking programs parameter list). Link-edit user exits (if necessary). Validate SORTIN/SORTINnn, SORTJNF1/SORTJNF2, and SORTOUT/SORTOFxx/ SORTOFx/SORTXSUM DCB attributes.

Chapter 8. The Flow of the Sort

8.1

If COPY with JOINKEYS, GO TO -

JOIN Non-Sorting Phase 3

If MERGE or COPY, GO TO -

Non-Sorting non-JOIN Phase 3

variable-length record sampling: open SORTIN, do the sampling, close SORTIN.

GO TO

Phase 1

Phase 1 non-JOIN Load Phase 1 exits. Call E11. Call E18. Open SORTIN. Perform SKIPREC processing. On the record level: Read from SORTIN or DB2 database for DB2 query. Call E15. Perform INCLUDE/OMIT processing. Perform INREC processing. Perform STOPAFT processing. Call E61. Perform SUM processing. Call E14.

8.2

SyncSort for z/OS 1.2 Programmers Guide

Call E16. Close SORTIN. Call E17. GO TO INCORE SORT Determination

Phase 1 JOIN Open SORTJNF1, SORTJNF2. On the record level: Read from SORTJNF1, SORTJNF2. Perform JOINKEYS SORTJNF2. INCLUDE/OMIT parameter processing, SORTJNF1,

Perform JOIN processing. Perform INCLUDE/OMIT processing. Perform INREC processing. Perform STOPAFT processing. Perform SUM processing.

Close SORTJNF1, SORTJNF2.

INCORE SORT Determination

If there is sufficient memory, GO TO

Incore Sort

Delete Phase 1 exits.

Chapter 8. The Flow of the Sort

8.3

If all strings can be merged at once, GO TO

Sorting Phase 3

GO TO

Phase 2

Incore Sort Delete Phase 1 exits. Load Phase 3 exits. Call E31. Call E39. Open SORTOUT. On the record level: Call E35. Write to SORTOUT.

Close SORTOUT. Call E37. Delete Phase 3 exits.

GO TO

Program Termination

Phase 2 Load Phase 2 exits. Call E21. On the record level:

8.4

SyncSort for z/OS 1.2 Programmers Guide

Call E25. Perform SUM processing.

Call E27. Delete Phase 2 exits.

GO TO

Sorting Phase 3

Sorting Phase 3 Load Phase 3 exits. Take checkpoint. Call E31. Call E39. Open SORTOUT, SORTOFxx, SORTOFx and SORTXSUM. On the record level: Perform SUM processing. Write to SORTXSUM. Perform OUTREC processing. Call E35. If SORTOUT, SORTOFxx or SORTOFx are present, then for each output data set: Perform STARTREC/ENDREC processing. Perform SAMPLE processing. Perform INCLUDE/OMIT parameter processing. Perform SAVE processing. Perform SPLIT/SPLITBY processing.

Chapter 8. The Flow of the Sort

8.5

Perform SortWriter functions. Perform OUTREC processing. Perform ANSI control character processing. Write to SORTOUT, SORTOFxx, or SORTOFx.

Call E37. Close all data sets. Delete Phase 3 exits.

GO TO

Program Termination

Non-Sorting, non-JOIN Phase 3 Load user exits for the merge/copy. Call E31. Call E38. Call E39. Open all data sets. Perform SKIPREC processing (for a copy). On the record level: Read from SORTIN/SORTINnn or DB2 database for DB2 query or (for a merge) call E32 for a record. Call E15 (for a copy). Perform INCLUDE/OMIT processing. Perform INREC processing. Perform STOPAFT processing (for a copy).

8.6

SyncSort for z/OS 1.2 Programmers Guide

Call E61 (for a merge). Perform SUM processing (for a merge). Write to SORTXSUM (for a merge). Perform OUTREC processing. Call E35.

If SORTOUT, SORTOFxx or SORTOFx are present, then for each output file: Perform STATREC/ENDREC processing. Perform SAMPLE processing. Perform INCLUDE/OMIT parameter processing. Perform SAVE processing. Perform SPLIT/SPLITBY processing. Perform SortWriter functions. Perform OUTREC processing. Perform ANSI control character processing. Write to SORTOUT, SORTOFxx or SORTOFx.

Call E37. Close all data sets. Delete user exits.

GO TO

Program Termination

JOIN NonSorting Phase 3

Open SORTJNF1, SORTJNF2. On the record level:

Chapter 8. The Flow of the Sort

8.7

Read from SORTJNF1, SORTJNF2. Perform JOINKEYS SORTJNF2. INCLUDE/OMIT parameter processing, SORTJNF1,

Perform JOIN processing. Perform INCLUDE/OMIT processing. Perform INREC processing. Perform STOPAFT processing. Perform OUTREC processing. Call E35.

If SORTOUT, SORTOFxx or SORTOFx are present, then for each output file: Perform STARTREC/ENDREC processing. Perform SAMPLE processing. Perform INCLUDE/OMIT parameter processing. Perform SAVE processing. Perform SPLIT/SPLITBY processing. Perform SortWriter functions. Perform OUTREC processing. Perform ANSI control character processing. Write to SORTOUT, SORTOFxx or SORTOFx.

Close all data sets. Delete E35 exit if loaded.

GO TO

Program Termination

Program Termination

8.8

SyncSort for z/OS 1.2 Programmers Guide

Print SyncSort messages. END.

Chapter 8. The Flow of the Sort

8.9

8.10

SyncSort for z/OS 1.2 Programmers Guide

Chapter 9. MAXSORT

MAXSORT: A Maximum Capacity Sort


MAXSORT is a maximum capacity sort designed to sort amounts of data that are too large for an ordinary sorting technique to process. MAXSORT breaks up the sorting process into small, individual sorts. At the end of each individual sort a natural breakpoint occurs. At this time, the sorted data is written out on intermediate storage devices and it becomes possible to stop the program without losing the results of the previous processing. At each breakpoint, an operator may intervene to change program options. When all the input to the sort has been read and has become individual sorted data sets, this output becomes input to one or more merges. If all the data sets can be merged at once, one final merge is performed. If all the data sets cannot be merged at once, some of them will be combined in one or more intermediate merges. Then, when all the data sets can be merged at one time, the final merge is performed and the final sorted output is produced. The diagrams on the following two pages illustrate the MAXSORT technique.

Chapter 9. MAXSORT

9.1

9.2

SyncSort for z/OS 1.2 Programmers Guide

Chapter 9. MAXSORT

9.3

MAXSORTs Advantages
Without MAXSORT, overlarge sorts require tape work areas or force the user to segment the input and execute multiple disk sorts. With MAXSORT, any input data set can be handled by one sort execution using disk work space. MAXSORT requires less disk space than ordinary sorts. Because MAXSORT stores the output of each individual sort on tape, the same disk SORTWK files can be used over and over again. Since the output of each individual sort is a completely sorted data set, the original job may be interrupted for higher priority jobs without wasting processing time. If a system or program failure occurs, whatever data sets have already been produced are still usable. The job can be restarted at the last breakpoint, and all previously produced data sets can be used without resorting.

Job Control Language


MAXSORT and Disk Sort have similar JCL requirements. To initiate MAXSORT using job control statements, specify PARM='MAXSORT' on the EXEC statement. A program-initiated sort requests MAXSORT by using a PARM card image in the data set defined by the $ORTPARM DD statement. In either case, it may be necessary to request additional main storage in order to use the MAXSORT technique.

Sample EXEC Statement

PGM=SYNCSORT PGM=SORT //stepname EXEC PGM=IERRCO00 PGM=IGHRCO00 PGM=ICEMAN Figure 207. MAXSORT EXEC Statement

DD Statements
MAXSORTs DD statement requirements are summarized in the following table. As many as three additional types of DD statements may be needed. Note that SORTWK files must be allocated only to disk devices.

9.4

SyncSort for z/OS 1.2 Programmers Guide

MAXSORT DD Statements //$ORTPARM //SYSIN DD DD Used to override PARM or control statement information. Control statement data set. Required unless the address of a 24bit or 31-bit extended parameter list is supplied by an invoking program. Message data set. Required unless all messages are routed to console. Disk work area definition. Required unless DYNALLOC is specified or MAXSORT is restarted at a MERGE breakpoint. SORT input data set. Required unless there is an E15. Ignored if the invoking program supplies an inline E15 exit routine; optional if the MODS statement activates an E15 exit routine. Output data set. Required unless there is an E35. Ignored if the invoking program supplies an inline E35 exit routine; optional if the MODS statement activates an E35 exit routine. Output data set for records deleted by SUM. Required if XSUM parameter used. Breakpoint data set. Must be DASD. Required. Required if intermediate output is on tape. Required if intermediate output is on disk or if intermediate output is on tape and DYNATAPE is not specified. Checkpoint data set. Required if Checkpoint-Restart is used. Required if user exits are in SYSIN and if user exits are to be linkage-edited at execution time.

//SYSOUT //SORTWKnn //SORTIN

DD DD DD

//SORTOUT

DD

//SORTXSUM //SORTBKPT //SORTOU00 //SORTOUnn //SORTCKPT //SORTMODS //SYSLIN //SYSLMOD //SYSUT1 //SYSPRINT //ddname

DD DD DD DD DD DD DD DD DD DD DD

Required for exits unless the exit is inline in LINKLIB/JOBLIB/ STEPLIB or in SYSIN. Table 39. MAXSORT DD Statements

When the RELEASE=ON parameter is active (either via specification or by default) at the conclusion of the sort portion of a MAXSORT, most of the allocated SORTWK space is free (however, in the case of invoked sorts or SORTWKs defined as OLD, the data set is returned to the size allocated at MAXSORT initiation rather than the minimum size possible). The SORTBKPT, SORTOU00, SORTOUnn and SORTCKPT DD statements are discussed below. Refer to Chapter 4. JCL and Sample JCL/Control Statement Streams for a discussion of the other DD statements, which are specified for MAXSORT just as they would be specified for Disk Sort.

Chapter 9. MAXSORT

9.5

SORTBKPT DD Statement
The required SORTBKPT statement defines the breakpoint data set on which the sort control information is stored. At the end of each individual sort or merge, a breakpoint is reached and the information in the breakpoint data set is automatically amended. However, when MAXSORT is program-invoked or when any exit other than an E35 exit is being used, breakpoints cannot be taken. Nevertheless, the SORTBKPT statement must be specified for all MAXSORTs, even those for which a breakpoint restart is not possible.

Allocating Disk Space for the Breakpoint Data Set


The breakpoint data set must be allocated on a direct access device. It is recommended that space for the breakpoint data set be allocated in the job step preceding the sort step. Or, the breakpoint data set may be pre-allocated in a separate job.

Sample Allocation of the Breakpoint Data Set


The following example illustrates how disk space for a breakpoint data set might be allocated as part of a MAXSORT job control stream. These two statements would follow the JOB statement:

//ALLOC //BKPTDATA //

EXEC PGM=IEFBR14 DD DSN=BKPT.DATA,DISP=(NEW,CATLG),UNIT=SYSDA, SPACE=(1000,(100,50))

Figure 208. Sample Job Step Allocating Disk Space for a Breakpoint Data Set In this example, the name of the breakpoint data set is BKPT.DATA. Because this data set must be kept until MAXSORT has completed, DISP=(NEW,CATLG) has been specified. Supplying approximately 100K bytes of primary space and allowing for secondary allocation should be adequate.

Sample SORTBKPT DD Statement


The sample SORTBKPT DD statement which follows identifies the breakpoint data set for which disk space has already been allocated.

//SORTBKPT

DD

DSN=BKPT.DATA,DISP=(OLD,KEEP) Figure 209. Sample SORTBKPT DD Statement

This SORTBKPT DD statement defines the breakpoint data set for which disk space has previously been allocated. The data set name must be the same name which was specified when the space for the breakpoint data set was allocated. DISP=(OLD,KEEP) is specified

9.6

SyncSort for z/OS 1.2 Programmers Guide

so that this statement does not have to be changed if MAXSORT is restarted. The DCB information should not be coded because MAXSORT supplies these values. If a VOLSER was coded when the disk space for the breakpoint data set was allocated, the same VOLSER must be specified in the SORTBKPT DD statement.

SORTOU00 DD Statement
The SORTOU00 DD statement is required for every MAXSORT application in which the intermediate output is stored on tape. The SORTOU00 DD statement defines the unit to be used for the output of the individual sorts and intermediate merges. MAXSORT will create and name these data sets which will eventually be merged to produce the final sorted output. The data set names generated will have one of the two formats. If the TIMESTMP option is not specified (the installation default), data set names will have the format: Snn TDS.jobname. Mnn If the TIMESMP option is specified at installation time, data set names will have the format: Snn TDS.Ddddhhmm.jobname. Mnn In either case, the S or M indicates whether the output is from the sort phase or from the merge phase; nn is the relative number of the data set (01 to 99). The Ddddhhmm time stamp refers to the time (Julian day, hour and minute) the sort began. The prefix default (TDS.) can be changed by specifying the BKPTDSN PARM option. The following rules should be observed in coding the SORTOU00 DD statement: Specify DISP=(NEW,KEEP) and a permanent DSNAME and VOL=PRIVATE so that a scratch tape is used and the volumes are unloaded. Failure to specify this can result in the rewinding of the scratch tape and overwriting of the intermediate sort output. Specify the DEFER option in the UNIT parameter so that mount messages to the operator that do not pertain to MAXSORT are suppressed. SORTOU00 and SORTIN cannot share the same tape unit. However, SORTOU00 and SORTOUT may share the same tape unit unless the DYNATAPE PARM is specified. SORTIN and SORTOUT may always share the same unit.

Chapter 9. MAXSORT

9.7

If DYNATAPE is in effect, the tape unit name must be the same as the unit name specified in the TAPENAME PARM.

Sample SORTOU00 DD Statement

//SORTOU00 //

DD

DSN=PERM.OU00,DISP=(NEW,KEEP), UNIT=(TAPE,,DEFER),VOL=PRIVATE Figure 210. Sample SORTOU00 DD Statement

SORTOUnn DD Statements
The SORTOUnn DD statements allocate the tape units used as input to the merge phase. They are required unless the DYNATAPE option (available only under z/OS) is used. Although it is not necessary to specify the SORTOUnn DD statements when DYNATAPE is used, it is a good idea to pre-allocate at least two SORTOUnn data sets when the DYNATAPE option is specified. This ensures that the minimum required number of tape units will be available for the merge phase. When additional units are available, DYNATAPE will provide performance benefits. The following rules should be observed in coding the SORTOUnn DD statements: At least two tape units must be allocated in the absence of DYNATAPE. However, allocating more units will make the merge phase complete more quickly. Each statement must be allocated to a unique tape drive. If DYNATAPE is in effect, the tape unit name must be the same as the unit name specified in the TAPENAME PARM. All the tape units must operate at the same recording density. For best performance, multiple density units should be run at the highest density. For each SORTOUnn statement, replace the 'nn' with a two digit number between 01 and 99. The numbers need not be consecutive. Specify DISP=(NEW,KEEP), a permanent DSNAME and VOL=PRIVATE so that a scratch tape is used and the tape volumes are unloaded. Specify the DEFER option in the UNIT parameter so that mount messages to the operator that do not pertain to MAXSORT are suppressed.

9.8

SyncSort for z/OS 1.2 Programmers Guide

Sample SORTOUnn DD Statements

//SORTOU01 // //SORTOU02 //

DD DD

DSN=PERM.OU01,DISP=(NEW,KEEP), UNIT=(TAPE,,DEFER),VOL=PRIVATE DSN=PERM.OU02,DISP=(NEW,KEEP), UNIT=(TAPE,,DEFER),VOL=PRIVATE Figure 211. Sample SORTOUnn DD Statements

Using Disk for Intermediate Output


In most cases, tape units will be used to store the intermediate output of the individual sorts and intermediate merges. However, it may be desirable in some circumstances to place intermediate output on disk (e.g., to take advantage of a mass storage subsystem). Assigning the intermediate output to a mass storage subsystem will not compromise the sorts efficiency. Because these files will be written and read sequentially, paging will be minimal. If disk is used for intermediate storage, the following rules should be observed: The SORTOU00 statement should not be coded. SORTOUnn statements may be allocated to real or MSS virtual volumes. To determine how many SORTOUnn DD statements to supply, divide the total number of bytes of sort input data by the number of bytes of SORTWK space and add 2 to the result. This figure is the number of SORTOUnn statements to supply. If too few SORTOUnn DD statements are supplied, MAXSORT will terminate for restart at the point at which a new DD statement is needed. Each SORTOUnn DD statement must allocate enough primary and secondary space to hold all of the data written during that intermediate sort. Track overflow is not supported for disk SORTOUnn data sets. Record lengths must not exceed the track capacity unless VS or VBS records are being processed.

SORTCKPT DD Statement
This DD statement is required in order to restart a MAXSORT which is task-invoked or includes a user exit routine because in these cases MAXSORT cannot be restarted from a breakpoint. The standard OS/VS Checkpoint-Restart feature is used. Both automatic Checkpoint-Restart and deferred Checkpoint-Restart capabilities are supported (see Chapter 13. Performance Considerations). Checkpoints are taken at the end of each intermediate sort or merge.

Chapter 9. MAXSORT

9.9

The SORTBKPT DD statement must be specified in addition to the SORTCKPT DD statement even when MAXSORT cannot be restarted from a breakpoint. A MAXSORT with an E35 exit does not require the SORTCKPT DD statement.

Control Statements
Control statements will only be accepted at the initial execution of MAXSORT. If MAXSORT is restarted, the control statements cannot be changed. Except for MERGE and OUTFIL, all SyncSort control statements are fully supported for MAXSORT.

PARM Options
The MAXSORT parameters described below may be specified on the EXEC statement, the $ORTPARM DD statement, PARMTBLE or PARMEXIT, and may be listed in any order.

BKPTDSN
cc...c. BKPTDSN= TDS. The BKPTDSN PARM is used to change the prefix of the data set names for the output of the individual sorts and intermediate merges. TDS. is the delivered default. The last character of the prefix must be a period. If the TIMESTMP option was specified at installation time, up to 21 characters may precede that period. Otherwise, up to 31 characters may be specified before the final period.

DYNATAPE
DYNATAPE NODYNATAPE DYNATAPE instructs MAXSORT to dynamically allocate any tapes needed as input for the merge phase. DYNATAPE may be used instead of (or as a supplement to) SORTOUnn DD statements. NODYNATAPE, the default, disables dynamic allocation.

MAXSORT

MAXSORT

9.10

SyncSort for z/OS 1.2 Programmers Guide

This parameter is required in order to execute MAXSORT.

MAXWKSP
MAX MAXWKSP= nM n This option specifies the maximum amount of disk SORTWK space that MAXSORT can use. When this parameter is used, MAXSORT will release excess space in order to meet the figure specified by the user. When the RELEASE=ON parameter is active (either via specification or by default) at the conclusion of the sort portion of a MAXSORT, most of the allocated SORTWK space is freed (however, in the case of invoked sorts or SORTWKs defined as OLD, the data set is returned to the size allocated at MAXSORT initiation rather than the minimum size possible). If MAX, the default value, is specified, all primary and secondary space which has been allocated will be acquired. The MAXWKSP value may also be specified as a decimal number of cylinders (n) or as a decimal number of megabytes (nM) of work space. If MAXWKSP is specified as n cylinders, MAXSORT will convert the specification to an actual byte value. MAXSORT will multiply by n the capacity of a cylinder on the disk allocated to the lowest-numbered SORTWKnn DD statement. Note: MAXWKSP should be specified as greater than or equal to MINWKSP, if specified.

MINWKSP
8 MINWKSP= nM n This option specifies the minimum amount of disk SORTWK space that MAXSORT can use. If the MINWKSP value exceeds the primary allocation and sufficient secondary allocation cannot be obtained to meet the MINWKSP value at the time of execution, the sort terminates. It can be restarted later when more space is available. The MINWKSP value may be specified as a decimal number of cylinders (n) or a decimal number of megabytes (nM) of work space. The default MINWKSP value is 8 cylinders.

Chapter 9. MAXSORT

9.11

If MINWKSP is specified as n cylinders, MAXSORT will convert the specification to an actual byte value. MAXSORT will multiply by n the capacity of a cylinder on the disk allocated to the lowest-numbered SORTWKnn DD statement. Note: MINWKSP should be specified as less than or equal to MAXWKSP, if specified.

RESTART
LAST RESTART= NO id This parameter specifies the point at which restart is to occur. LAST, the default value, requests that the sort start at the most recent breakpoint. NO specifies that the SORTBKPT data set is to be cleared so that it can be used for a new job. (Be sure to specify NO only when the SORTBKPT data set is empty or should be destroyed.) To restart at a particular breakpoint, code its id number. The breakpoint id number is provided by message WER350I.

SORTSIZE
n SORTSIZE= nM nT This option is accepted but ignored. Its function has been replaced by SyncSort internal techniques.

SORTTIME
n SORTTIME= 1440 The SORTTIME parameter terminates the sort at the next breakpoint after n minutes of clock time have elapsed. (The sort may be restarted later.) The default is 1440 minutes (24 hours). If this parameter is omitted or 1440 is specified, the sort will not terminate prematurely.

9.12

SyncSort for z/OS 1.2 Programmers Guide

This parameter may be specified with operator communication at installation time. If operator communication is specified, the sort will be interrupted at the next breakpoint after the specified amount of time has elapsed and the operator will be asked whether to terminate the sort or continue until the next breakpoint.

TAPENAME
name TAPENAME= TAPE This parameter specifies the tape unit generic name for dynamic tape allocation. The default TAPENAME is TAPE. If the TAPENAME parameter is specified, the same unit generic name must be specified for both the SORTOU00 and the SORTOUnn DD statements. The tape unit generic name must be a valid unit name at your installation.

Exit Programs
All the exits available for Disk Sort are supported for MAXSORT. However, since MAXSORT never runs out of work space on even the largest sorts, an E16 exit routine will never be called. Exit routines may be written in COBOL, C, Assembler language, or REXX. All exits should be prelink-edited for maximum efficiency. The following rules must be observed when MAXSORT includes an exit routine: Exit programs are not allowed to take their own z/OS checkpoints. MAXSORT may take system checkpoints when the following exits are active: E14, E15, E25, E35 and E61. Since a checkpoint may be taken between any two calls of these exits, these routines should be coded accordingly. Any restrictions that apply to system Checkpoint-Restart, such as restrictions on the use of data sets, are applicable to the coding of these exit routines.

Invoking MAXSORT from a Program


MAXSORT can be invoked from programs written in COBOL, PL/1 or Assembler language. However, this is the least efficient method of executing MAXSORT and performance benefits will be realized if MAXSORT is initiated through job control language. When MAXSORT is invoked from a program, the MAXSORT PARM should be specified in the $ORTPARM DD statement. The SYSIN DD statement is ignored.

Chapter 9. MAXSORT

9.13

Restarting MAXSORT
A JCL-initiated MAXSORT can be restarted from a breakpoint if necessary. When MAXSORT is restarted from a breakpoint, the following PARM options cannot be modified: CMP=CPD/CLC, EQUALS, E15/E35=COB, FILSZ, LOCALE, MAXSORT, STOPAFT and TAPENAME. Other PARM options will be accepted if they are specified on the EXEC statement. Only the CORE parameter can be passed through $ORTPARM. SyncSort control statements cannot be modified when MAXSORT is restarted. However, the l5, l6 and l7 values on the LENGTH parameter of the RECORD control statement can be altered.

Restarting MAXSORT with Exit Routines or an Invoked MAXSORT


When MAXSORT includes an exit routine or is invoked from a program, it cannot be restarted from a breakpoint. Instead, it can be restarted from a checkpoint using the standard OS/VS Checkpoint-Restart feature. Checkpoints are taken at the end of each intermediate sort or merge. When MAXSORT is restarted from a checkpoint, modified PARM options cannot be specified on the EXEC statement. Only the CORE parameter can be passed through $ORTPARM. To specify that checkpoints be taken for a MAXSORT with an exit routine or for an invoked MAXSORT, the following rules must be observed: Include the SORTCKPT DD statement in the JCL (in addition to the SORTBKPT DD statement. Assign a permanent data set name to every SORTWKnn DD statement and specify DISP=(NEW,DELETE,KEEP). Specify RD=R and MSGLEVEL=1 on the JOB statement. Specify the CKPT parameter on the SORT/MERGE control statement.

MAXSORTs Operator Interface


If MAXSORTs operator interface options are enabled when SyncSort is installed, they will permit operator communication at selected breakpoints (e.g., at the first breakpoint after SORTTIME has expired, or when tape drives are dynamically allocated under DYNATAPE.) Operator communication allows the operator to examine the environment at execution time to decide whether or not to terminate MAXSORT at that breakpoint. If the operator decides to terminate the sort, it can be restarted later at that breakpoint. All the previously produced sorted data sets can be used without resorting.

9.14

SyncSort for z/OS 1.2 Programmers Guide

Operator communication with MAXSORT is not a delivered default - these options must be enabled at SyncSort installation time. For example, if MAXSORTs assigned block of computer time (its SORTTIME value) has been exhausted and SyncSort was installed to permit operator intervention at such times, message WER375D is generated.

WER375D PAYROLL.SORTSTEP - MAXSORT BKPT PAYROLL S12 WER375D TIME ESTIMATE: 30 MINUTES UNTIL NEXT NOTIFICATION WER375D REPLY 'GO' TO CONTINUE, 'STOP' TO TERMINATE Figure 212. Example: Operator Notification at SORTTIME Expiration The operator receiving this message can decide to terminate the sort or allow it to continue, basing his decision on scheduling priorities and the estimated time of the sort. When another 30 minutes have passed, the operator will be asked again whether or not MAXSORT should be terminated. When DYNATAPE is specified and operator communication has been enabled at installation time, message WER376D may be generated to report the results of the dynamic allocation attempt.

WER376D WER376D WER376D WER376D WER376D WER376D

PAYROLL.SORTSTEP - MAXSORT BKPT PAYROLL.S01 4 TAPE UNITS ALLOCATED TO PAYROLL 6 TAPE UNITS NEEDED FOR BEST PERFORMANCE TIME ESTIMATE USING 4 TAPE UNITS-20 MINUTES TO NEXT BREAKPOINT REPLY 'GO' TO CONTINUE, 'STOP' TO TERMINATE, 'NN' # UNITS Figure 213. Example: Operator Notification with DYNATAPE

If the operator responds 'GO', MAXSORT will execute with four tape units. If the operator responds 'STOP', MAXSORT will terminate. If the operator responds with a number ('NN'), MAXSORT will try to allocate that total number of tape drives. Ideally, the operator should specify six for 'NN' because MAXSORT needs six tape units for best performance. If the operator requests additional tape units, message WER376D will be reissued. The operator will again be prompted for a 'GO', 'STOP' or 'NN' reply. In this way, the operator can balance the requirements of MAXSORT against the requirements of other jobs that are executing at the same time. When DYNATAPE is specified, there may not be enough tape units available for dynamic allocation. In this case, message WER377D is generated.

Chapter 9. MAXSORT

9.15

WER377D WER377D WER377D WER377D WER377D

PAYROLL.SORTSTEP - MAXSORT BKPT PAYROLL.S01 INSUFFICIENT TAPE UNITS AVAILABLE 2 TAPE UNITS ALLOCATED TO PAYROLL 4 TAPE UNITS NEEDED TO CONTINUE EXECUTION REPLY 'RETRY' TO GET UNITS, 'STOP' TO TERMINATE

Figure 214. Example: Operator Notification of Insufficient Tape Units under DYNATAPE The operator receiving message WER377D can wait until additional tape drives have been released and then reply 'RETRY'. Or, the operator can answer 'STOP' to terminate the job and then restart it later when more tape drives become available. If the DYNATAPE and TAPENAME PARMs have been specified and all tape units on the system within the TAPENAME class have already been allocated, message WER378D is generated.

WER378D NO ADDITIONAL TAPE UNITS EXIST FOR GENERIC CLASS 2400-3 Figure 215. Example: Operator Notification of Insufficient Tape Units for TAPENAME Class Message WER378D is followed by message WER376D if the number of tape drives allocated is sufficient for execution, or by message WER377D if it is not sufficient.

9.16

SyncSort for z/OS 1.2 Programmers Guide

Sample MAXSORT JCL/Control Streams


The following examples illustrate how the JCL could be coded for typical 100 gigabyte MAXSORTs.

Example 1: A 100 Gigabyte MAXSORT with only Minimal Disk Space Available
An installation is running a 100 gigabyte sort and has a restricted amount of disk space available for SORTWK across ten volumes (WORK1, WORK2, ...WORK10). The JCL for this job follows.

Chapter 9. MAXSORT

9.17

//ALLOC EXEC PGM=IEFBR14 //BKPTDATA DD DSN=BKPT.DATA,DISP=(NEW,CATLG), // UNIT=SYSDA,SPACE=(1000,(100,50)) //SORT EXEC PGM=SYNCSORT,PARM='MAXSORT,MINWKSP=6000' //SORTBKPT DD DSN=BKPT.DATA,DISP=(OLD,KEEP) //SYSOUT DD ... //SORTIN DD ... //SORTOUT DD ... //SORTWK01 DD UNIT=SYSDA,SPACE=(CYL,(300,175)), // VOL=SER=WORK1 //SORTWK02 DD UNIT=SYSDA,SPACE=(CYL,(300,175)), // VOL=SER=WORK2 //SORTWK03 DD UNIT=SYSDA,SPACE=(CYL,(300,175)), // VOL=SER=WORK3 //SORTWK04 DD UNIT=SYSDA,SPACE=(CYL,(300,175)), // VOL=SER=WORK4 //SORTWK05 DD UNIT=SYSDA,SPACE=(CYL,(300,175)), // VOL=SER=WORK5 //SORTWK06 DD UNIT=SYSDA,SPACE=(CYL,(300,175)), // VOL=SER=WORK6 //SORTWK07 DD UNIT=SYSDA,SPACE=(CYL,(300,175)), // VOL=SER=WORK7 //SORTWK08 DD UNIT=SYSDA,SPACE=(CYL,(300,175)), // VOL=SER=WORK8 //SORTWK09 DD UNIT=SYSDA,SPACE=(CYL,(300,175)), // VOL=SER=WORK9 //SORTWK10 DD UNIT=SYSDA,SPACE=(CYL,(300,175)), // VOL=SER=WORK10 //SORTOU00 DD DSN=PERM.OU00,DISP=(NEW,KEEP), // UNIT=(TAPE,,DEFER),VOL=PRIVATE //SORTOU01 DD DSN=PERM.OU01,DISP=(NEW,KEEP), // UNIT=(TAPE,,DEFER),VOL=PRIVATE //SORTOU02 DD DSN=PERM.OU02,DISP=(NEW,KEEP), // UNIT=(TAPE,,DEFER),VOL=PRIVATE //SORTOU03 DD DSN=PERM.OU03,DISP=(NEW,KEEP), // UNIT=(TAPE,,DEFER),VOL=PRIVATE //SYSIN DD * SORT FIELDS=(1,10,CH,A) /*

1 2 3 4 5

7 8

Figure 216. Sample JCL Control Stream for a 100 Gigabyte MAXSORT

9.18

SyncSort for z/OS 1.2 Programmers Guide

1. This job step is run in order to allocate the disk space for the breakpoint data set via IBM utility program IEFBR14. 2. This statement allocates the space for the breakpoint data set. Specify (NEW,CATLG) because this data set must be saved. 3. The EXEC statement initiates the regular SyncSort program, and the MAXSORT PARM is specified, as required. This job requests a minimum of 6000 cylinders of disk space for SORTWKnn data sets. If that much space cannot be obtained during the job, the program will terminate. 4. The SORTBKPT DD statement is required for all MAXSORTs. It identifies the breakpoint data set which was allocated in the first job step. DISP=(OLD,KEEP) is specified so that this statement can be reused if MAXSORT is restarted. 5. These DD statements are coded just as they would be for an ordinary sort. 6. The SORTWKnn DD statements must be allocated to disk or MAXSORT will terminate. In this case, 3000 cylinders of primary space have been allocated. Secondary allocation could provide up to 2625 cylinders on each volume if that amount of free space exists. Since the MINWKSP PARM specifies at least 6000 cylinders, this program will terminate unless 3000 cylinders of secondary space can be obtained. 7. The SORTOU00 DD statement is required for this job because the intermediate sort output will be stored on tape. DISP=(NEW,KEEP), a permanent DSN and VOL=PRIVATE are specified to ensure that the system unloads each output tape. The DEFER option in the UNIT parameter is specified so that mount messages to the operator that do not pertain to MAXSORT are suppressed. 8. The SORTOU01, SORTOU02 and SORTOU03 DD statements allocate the tape units used as input to the merge phase. Permanent DSNAMEs, DISP=(NEW,KEEP), VOL=PRIVATE and the DEFER option in the UNIT parameter are all specified just as they were for the SORTOU00 DD statement. 9. The sort control statements are included here.

Chapter 9. MAXSORT

9.19

Example 2: Restarting the MAXSORT in Example 1 from a Breakpoint


Example 1 can be restarted from a breakpoint simply by submitting the original job control stream without the job step which allocated space for the breakpoint data set. The job will be restarted from the last breakpoint because RESTART=LAST is the default; it is not necessary to specify RESTART=LAST on the EXEC statement. The JCL for this job follows.

//SORT EXEC PGM=SYNCSORT,PARM='MAXSORT,MINWKSP=6000' //SORTBKPT DD DSN=BKPT.DATA,DISP=(OLD,KEEP) //SYSOUT DD ... //SORTIN DD ... //SORTOUT DD ... //SORTWK01 DD UNIT=SYSDA,SPACE=(CYL,(300,175)),VOL=SER=WORK1 //SORTWK02 DD UNIT=SYSDA,SPACE=(CYL,(300,175)),VOL=SER=WORK2 //SORTWK03 DD UNIT=SYSDA,SPACE=(CYL,(300,175)),VOL=SER=WORK3 //SORTWK04 DD UNIT=SYSDA,SPACE=(CYL,(300,175)),VOL=SER=WORK4 //SORTWK05 DD UNIT=SYSDA,SPACE=(CYL,(300,175)),VOL=SER=WORK5 //SORTWK06 DD UNIT=SYSDA,SPACE=(CYL,(300,175)),VOL=SER=WORK6 //SORTWK07 DD UNIT=SYSDA,SPACE=(CYL,(300,175)),VOL=SER=WORK7 //SORTWK08 DD UNIT=SYSDA,SPACE=(CYL,(300,175)),VOL=SER=WORK8 //SORTWK09 DD UNIT=SYSDA,SPACE=(CYL,(300,175)),VOL=SER=WORK9 //SORTWK10 DD UNIT=SYSDA,SPACE=(CYL,(300,175)),VOL=SER=WORK10 //SORTOU00 DD DSN=PERM.OU00,DISP=(NEW,KEEP), // UNIT=(TAPE,,DEFER),VOL=PRIVATE //SORTOU01 DD DSN=PERM.OU01,DISP=(NEW,KEEP), // UNIT=(TAPE,,DEFER),VOL=PRIVATE //SORTOU02 DD DSN=PERM.OU02,DISP=(NEW,KEEP), // UNIT=(TAPE,,DEFER),VOL=PRIVATE //SORTOU03 DD DSN=PERM.OU03,DISP=(NEW,KEEP), // UNIT=(TAPE,,DEFER),VOL=PRIVATE //SYSIN DD * SORT FIELDS=(1,10,CH,A) /* Figure 217. Sample JCL Control Stream for Restarting a 100 Gigabyte MAXSORT The JCL is identical to the JCL in Example 1 except that the step which allocated the disk space for the breakpoint data set is not resubmitted.

9.20

SyncSort for z/OS 1.2 Programmers Guide

Example 3: A 100 Gigabyte MAXSORT with Dynamic Tape Allocation


This example is identical to Example 1 with one difference: the DYNATAPE PARM requests dynamic tape allocation. The JCL for this job follows.

//ALLOC EXEC PGM=IEFBR14 //BKPTDATA DD DSN=BKPT.DATA,DISP=(NEW,CATLG),UNIT=SYSDA, // SPACE=(1000,(100,50)) //SORT EXEC PGM=SYNCSORT,PARM='MAXSORT,MINWKSP=6000, // DYNATAPE' //SORTBKPT DD DSN=BKPT.DATA,DISP=(OLD,KEEP) //SYSOUT DD ... //SORTIN DD ... //SORTOUT DD ... //SORTWK01 DD UNIT=SYSDA,SPACE=(CYL,(300,175)),VOL=SER=WORK1 //SORTWK02 DD UNIT=SYSDA,SPACE=(CYL,(300,175)),VOL=SER=WORK2 //SORTWK03 DD UNIT=SYSDA,SPACE=(CYL,(300,175)),VOL=SER=WORK3 //SORTWK04 DD UNIT=SYSDA,SPACE=(CYL,(300,175)),VOL=SER=WORK4 //SORTWK05 DD UNIT=SYSDA,SPACE=(CYL,(300,175)),VOL=SER=WORK5 //SORTWK06 DD UNIT=SYSDA,SPACE=(CYL,(300,175)),VOL=SER=WORK6 //SORTWK07 DD UNIT=SYSDA,SPACE=(CYL,(300,175)),VOL=SER=WORK7 //SORTWK08 DD UNIT=SYSDA,SPACE=(CYL,(300,175)),VOL=SER=WORK8 //SORTWK09 DD UNIT=SYSDA,SPACE=(CYL,(300,175)),VOL=SER=WORK9 //SORTWK10 DD UNIT=SYSDA,SPACE=(CYL,(300,175)),VOL=SER=WORK10 //SORTOU00 DD DSN=PERM.OU00,DISP=(NEW,KEEP), // UNIT=(TAPE,,DEFER),VOL=PRIVATE //SORTOU01 DD DSN=PERM.OU01,DISP=(NEW,KEEP), // UNIT=(TAPE,,DEFER),VOL=PRIVATE //SORTOU02 DD DSN=PERM.OU02,DISP=(NEW,KEEP), // UNIT=(TAPE,,DEFER),VOL=PRIVATE //SYSIN DD * SORT FIELDS=(1,10,CH,A) /* Figure 218. Sample JCL Control Stream for a 100 Gigabyte MAXSORT The DYNATAPE PARM requests that tape units be obtained dynamically. Because DYNATAPE has been specified, the SORTOU01, SORTOU02, and SORTOU03 DD statements specified in Example 1 do not have to be supplied. They will be created and dynamically allocated when needed. If enough tape units are available at the time the job is run, the sort will be successfully completed in one step.

Chapter 9. MAXSORT

9.21

However, there may not be enough tape devices available under dynamic allocation at execution time. In that case, the job will terminate and can be restarted at a later time when more tape units are available. For best results, code two SORTOUnn DD statements in addition to specifying the DYNATAPE PARM as the above example illustrates. This approach ensures that MAXSORT will have the minimum two tape units needed for the merge phase and also allows MAXSORT to take advantage of the additional tapes available under dynamic allocation.

Tuning MAXSORT
MAXSORTs performance can be optimized by controlling the intermediate sorts which it processes. A balance should be achieved between the number and duration of intermediate sorts. Limiting the number of sorts reduces the required tape mounts and restricting the duration of sorts decreases the interval between breakpoints. A good rule of thumb is that each intermediate sorted data set should create from one to five volumes of input data, and the only way to determine the amount of input data is by controlling the amount of SORTWK space used. This is illustrated in Figure 219.

1 3590 tape volume can contain 20 gigabytes 1 3390 cylinder can hold approximately 800,000 bytes SORTIN: 100 gigabytes (5 tape volumes) OBJECTIVE: Each intermediate sort processes one input volume, i.e. 5 intermediate sorts should be run. To determine SORTWK allocation (for 3390 SORTWKs): Divide one input volume 21,474,836,480 bytes by cylinder capacity 800,000 Quotient: 26844 cylinders.

To ensure 5 intermediate sorts: Allocate 26844 cylinders Set MAXWKSP=21759M Figure 219. Calculating MAXWKSP If only 3,000 cylinders were allocated in the preceding example, 45 intermediate sorts would be performed, increasing the required tape mounts and potential for error. If 75,000 cylinders were allocated, most of the input would be processed by the first intermediate sort, delaying the first breakpoint and introducing the potential for losing data. It is crucial, therefore, to allocate a balanced amount of DASD space that will divide your file into reasonably sized segments to minimize the possibility of system error and to enhance your performance.

9.22

SyncSort for z/OS 1.2 Programmers Guide

Before tuning MAXSORT then, a number of individual environmental elements should be considered. A study of disk and tape availability, input data file size, and virtual storage limitations will help you optimize the balance of performance and reliability.

Chapter 9. MAXSORT

9.23

9.24

SyncSort for z/OS 1.2 Programmers Guide

Chapter 10. PARASORT

PARASORT: Parallel Input Processing for Elapsed Time Improvement


PARASORT improves elapsed time performance for sorts whose input is a multi-volume tape data set and/or concatenated tape data sets. Reduced elapsed time can help critical sort applications achieve batch window goals. The performance improvement from PARASORT is a result of processing the SORTIN input volumes in a parallel fashion. Depending upon the resources provided, elapsed time can be reduced up to 20% for 2-way input and up to 33% for 4-way input. PARASORT requires additional tape units for the application. You will need from two to eight times the current number of tape units, depending upon resource availability and the degree of improvement desired. PARASORT automatically manages the tape units and minimizes the use of the tape drive resources by deallocating excess tape drives during initialization and releasing all the extra units at the end of the sort input phase.

PARASORT Applicability
Certain SyncSort facilities or application characteristics cannot be used with PARASORT. The following are incompatible with a PARASORT application: A SORTIN record format (RECFM) of VS or VBS. A SORTIN GDG with a relative reference specified.

Chapter 10. PARASORT

10.1

An ASCII tape data set specified for SORTIN. An exit routine other than a pre-linked or inline E35 exit. EQUALS specified either as an installation or run-time option. SKIPREC or STOPAFT options specified. SEQNUM specified on INREC. CKPT (checkpoint) option in effect. The MAXSORT option specified. The OUTREC CONVERT feature to convert VL records to FL format. Certain unusual sort key types, feature combinations, or long sort keys in excess of 800 bytes. FIELDS=COPY specified.

Job Control Language


The JCL for PARASORT is similar to the JCL for a standard disk sort. The primary difference is that PARASORT JCL must specify additional tape units to allow parallel input processing of the SORTIN data set. For details on SORTIN JCL for PARASORT, see SORTIN DD Statement with PARASORT on page 10.3. To initiate PARASORT using job control statements, specify PARM='PARASORT' on the EXEC statement. A program initiated sort requests PARASORT by using a PARM card image in the data set defined by the $ORTPARM DD statement.

Sample EXEC Statement


PGM=SYNCSORT PGM=SORT //stepname EXEC PGM=IERRCO00 ,PARM='PARASORT' PGM=IGHRCO00 PGM=ICEMAN Figure 220. PARASORT EXEC Statement

10.2

SyncSort for z/OS 1.2 Programmers Guide

DD Statements
PARASORTs DD statement requirements are summarized in the following table. One additional DD type (SORTPARn) is required compared to a conventional disk sort. PARASORT DD Statements //$ORTPARM //SYSIN DD DD Used to override PARM or control statement information. Control statement data set. Required unless the address of a 24bit or 31-bit extended parameter list is supplied by an invoking program. Message data set. Required unless all messages are routed to console. Disk work area definition. Required unless DYNALLOC is specified. SORT input data set. Required. Defines additional tape units for parallel reading of SORTIN. Required. Output data set. Required unless there is an E35. Ignored if the invoking program supplies an inline E35 exit routine; optional if the MODS statement activates an E35 exit routine. Output data set for records deleted by SUM. Required if XSUM parameter used. Required unless E35 user exit is in LINKLIB/JOBLIB/ STEPLIB. Table 40. PARASORT DD Statements

//SYSOUT //SORTWKxx //SORTIN //SORTPARn //SORTOUT

DD DD DD DD DD

//SORTXSUM //ddname

DD DD

The SORTIN and SORTPARn DD statements are discussed below. For a discussion of the other DD statements, which are specified for PARASORT just as for a non-PARASORT Disk Sort, see Chapter 4. JCL and Sample JCL/Control Statement Streams.

SORTIN DD Statement with PARASORT


The SORTIN DD statement is required for a PARASORT application. It must define either a single multi-volume tape data set or several concatenated tape data sets, which can be single or multi-volume. If the SORTIN is concatenated, each data set must meet the normal SORTIN concatenation requirements and must be able to use the same device type so that UNIT=AFF=SORTIN can be specified for all data sets in the concatenation. For a discussion of normal SORTIN JCL, see Chapter 4. JCL and Sample JCL/Control Statement Streams For optimal performance, data sets that reside on tapes, such as 3480s, that can be read only in a single direction should have two units allocated. If the data set is on a tape that supports bidirectional processing, a single unit is sufficient. In all cases DEFER mounting must be specified.

Chapter 10. PARASORT

10.3

SORTIN data sets may not be passed data sets or have PASS specified on their DD statement. Either the catalog or specific list of volume serial numbers must be specified. The volume serial list must accurately reflect the volumes in the data set. If extra volumes are specified (as may happen if an old data set is rewritten with less data) an error message will be generated. A volume sequence number may not be specified. The following example SORTIN DD statements for PARASORT illustrate three different SORTIN cases: A multi-volume cataloged data set A multi-volume uncataloged data set Concatenated single and multi-volume uncataloged data sets

Note that each example includes a y on the UNIT specification (for example, UNIT=(3480,y,DEFER)). The y is either 1 or 2 and indicates the number of units to be allocated for these devices. For optimal performance, data sets that reside on tapes that can be read only in a single direction, such as 3480s, should have two units allocated. If the data set is on a tape that supports bidirectional processing, a single unit is sufficient. In all cases DEFER mounting must be specified. Note also that each example includes an alternative UNIT specification: UNIT=(xxxxx1,y,DEFER). This specification applies if special esoteric names are available. The xxxxx1 is a special esoteric unit name established especially for PARASORT. These esoteric names may have been created at your site for use with PARASORT. Contact the systems programmer responsible for SyncSort installation to determine if they are available. For information on how to select a special esoteric name, see Special Channel Separated Esoteric Names on page 10.7

Example 1
SORTIN consists of a single multi-volume cataloged data set.

//SORTIN DD DSN=INPUT.FILE,DISP=(OLD,KEEP), // UNIT=(,y,DEFER) or if a special esoteric name is available // UNIT=(xxxxx1,y,DEFER) Figure 221. Sample SORTIN DD Statement

10.4

SyncSort for z/OS 1.2 Programmers Guide

Example 2
SORTIN consists of a single multi-volume uncataloged data set.

//SORTIN DD DSN=INPUT.FILE,DISP=(OLD,KEEP), // UNIT=(3480,y,DEFER),VOL=SER=(VOL001,VOL002,...,VOL00N) or if special esoteric name is available // UNIT=(xxxxx1,y,DEFER),VOL=SER=(VOL001,VOL002,...,VOL00N) Figure 222. Sample SORTIN DD Statement This example presumes the file is standard label and the first file is on VOL001. For uncataloged data sets, the unit and volser list must be specified.

Example 3
SORTIN consists of a concatenation of single and multi-volume uncataloged data sets.

//SORTIN DD DSN=INPUT.FILE1,DISP=(OLD,KEEP), // UNIT=(3480,y,DEFER),VOL=SER=(VOL001,VOL002,VOL003) or if special esoteric names are available // UNIT=(xxxxx1,y,DEFER),VOL=SER=(VOL001,VOL002,VOL003) // DD DSN=INPUT.FILE2,DISP=(OLD,KEEP), // UNIT=AFF=SORTIN,VOL=SER=(VOL101,VOL102) // DD DSN=INPUT.FILE3,DISP=(OLD,KEEP), // UNIT=AFF=SORTIN,VOL=SER=(VOL201) Figure 223. Sample SORTIN DD Statement It is also possible to include a DD DUMMY allocation in the SORTIN concatenation. This is necessary when modifying production JCL that is a prototype for the maximum number of possible concatenated input files. If a particular execution uses less than the maximum number, place the DD DUMMY specification at the appropriate point. This specification should contain a DCB specification that matches that of the first SORTIN data set.

SORTPARn DD Statements
The SORTPARn DD statements define units that will be used to perform the parallel reading of the input file. Up to four SORTPARn DD statements may be provided, with a minimum of two required. The number of SORTPARn DD statements that you provide may be limited by the tape channel capacity at your installation. See Special Channel Separated Esoteric Names on page 10.7 for information on how to determine if your choice is limited. The n in the SORTPARn is replaced with numbers 1 through 4. The numbers must start at 1 and be numbered consecutively.

Chapter 10. PARASORT

10.5

The required SORTPAR1 must be coded in one of the following two ways, depending on whether the SORTIN data set is cataloged or not. If the SORTIN DD is defined as a single cataloged data set or as a series of concatenated data sets where the first data set of the concatenation is cataloged, then the SORTPAR1 DD must be coded as follows:

//SORTPAR1 //

DD DSN=*.SORTIN,DISP=OLD, UNIT=AFF=SORTIN Figure 224. Sample SORTPAR1 DD Statement

If the SORTIN DD is defined as a single non-cataloged data set or as a series of concatenated data sets where the first data set of the concatenation is non-cataloged, then the SORTPAR1 DD must be coded as follows:

//SORTPAR1 //

DD DSN=*.SORTIN,DISP=OLD,UNIT=AFF=SORTIN, VOL=SER=(VOL001,VOL002,...,VOL00n) Figure 225. Sample SORTPAR1 DD Statement

where the VOL=SER list contains the identical volumes specified on the SORTIN DD specification. If the SORTIN DD is a series of concatenations, the VOL=SER list is the volumes that comprise the first data set in the concatenation. The remaining SORTPARnn DDs are coded as shown on the following prototype SORTPARnn DD statement:

//SORTPARn // //

DD DSN=*.SORTIN,DISP=(,KEEP,KEEP), VOL=PRIVATE,UNIT=(xxxx,y,DEFER) or if special esoteric names are available VOL=PRIVATE,UNIT=(xxxxxn,y,DEFER) Figure 226. Prototype SORTPARn DD Statement

The xxxx is a unit type or generic name compatible with the device associated with SORTIN. If special channel separated esoteric names have been made available, see Special Channel Separated Esoteric Names on page 10.7. The y is either 1 or 2 and indicates the number of units to be allocated for these devices. For optimal performance, data sets that reside on tapes that can be read only in a single direction, such as 3480s, should have two units allocated. If the data set is on a tape that supports bidirectional processing, a single unit is sufficient. In all cases DEFER mounting must be specified.

10.6

SyncSort for z/OS 1.2 Programmers Guide

The number of SORTPARn data sets to allocate depends on several factors: The total number of volumes to be read from SORTIN and its concatenations. There is no need to allocate more SORTPARn data sets than total volumes in the SORTIN file. Note that if more SORTPARn data sets are allocated than there are volumes, the excess SORTPARn data sets will be deallocated at PARASORTs initiation. The degree of performance improvement desired. Typically, two SORTPARn datasets will provide up to 20% elapsed time improvement; three, up to 25%; and four, up to 33%. The degree of channel contention, which may reduce the number of SORTPARn DD statements used. The use of special esoteric unit names will ensure that this contention is eliminated, but your choice for the number of SORTPARn DD statements may be limited. Resource availability. System constraints may limit the number available to a particular job.

Special Channel Separated Esoteric Names


For optimal PARASORT performance, SyncSort must be able to read each SORTPARn input DD simultaneously, with no channel contention. To ensure this, your system programming staff may have defined special esoteric unit names for use with PARASORT. Before creating a PARASORT application, you should contact your system programmer to verify that this work has been done and that the special names are available for use. Note, however, that even if the work has been done, certain categories may be unavailable due to limited channel capacity. To use special esoteric names, do the following: 1. Decide whether you would like to specify 4-way (up to SORTPAR4), 3-way (up to SORTPAR3) or 2-way (up to SORTPAR2) input. 2. In the table of special esoteric names provided by your systems programmer, find the name that corresponds to the tape type of the SORTIN data sets. The following is a sample table of special esoteric names. This table is for illustration only; the names at your site may be different.

Chapter 10. PARASORT

10.7

4-WAY INPUT

3-WAY INPUT

2-WAY INPUT

3420 3480/90 3490E 3590 |----------|----------|----------|----------| | PAR241 | PAR441 | PARE41 | NOT | | PAR242 | PAR442 | PARE42 | POSSIBLE | | PAR243 | PAR443 | PARE43 | | | PAR244 | PAR444 | PARE44 | | |----------|----------|----------|----------| | PAR231 | PAR431 | PARE31 | NOT | | PAR232 | PAR432 | PARE32 | POSSIBLE | | PAR233 | PAR433 | PARE33 | | |----------|----------|----------|----------| | PAR221 | PAR421 | PARE21 | PAR921 | | PAR222 | PAR422 | PARE22 | PAR922 | |----------|----------|----------|----------| Figure 227. Sample Esoteric Unit Name Table

3. Use the name from the table at your site for your SORTIN and SORTPARn names. The following example JCL is for input from 3480 cartridges with at least 4 volumes:

//SORTIN //SORTPAR1 // //SORTPAR2 // //SORTPAR3 // //SORTPAR4 //

DD DSN=....,DISP=(OLD,KEEP),UNIT=(PAR441,2,DEFER) DD DSN=*.SORTIN,DISP=OLD, UNIT=AFF=SORTIN DD DSN=*.SORTIN,DISP=(,KEEP,KEEP), VOL=PRIVATE,UNIT=(PAR442,2,DEFER) DD DSN=*.SORTIN,DISP=(,KEEP,KEEP), VOL=PRIVATE,UNIT=(PAR443,2,DEFER) DD DSN=*.SORTIN,DISP=(,KEEP,KEEP), VOL=PRIVATE,UNIT=(PAR444,2,DEFER)

Sortwork Considerations
The amount of sortwork space required is the same as if the application were run as a conventional sort. What should be modified, if sortworks are provided via JCL rather than DYNALLOC, is the number of SORTWKxx DD statements. Try to provide a total number of SORTWKxx DDs that is two to three times the number of SORTPARns specified. This would typically require an adjustment in primary and secondary space amounts so that the total space allocated is similar to that of the original application. This subdivision of SORTWORK space will provide an opportunity for additional channel path availability. This parallelism in SORTWORK channel paths is also a key to improving sort elapsed time performance.

10.8

SyncSort for z/OS 1.2 Programmers Guide

Operations Notes
Since the SORTIN tape volumes will be read in any order and on a SORTPARn tape unit location determined by the PARASORT logic, it is possible to receive messages on the console log that indicate out of sequence processing of the volumes of the SORTIN data set. Messages such as the following may be generated: IEC712I ... SORTPARn READ - NOT FIRST VOLUME OF DATA SET or IEC710I ... SORTPARn ANOTHER VOLUME EXPECTED These messages can be disregarded since this type of processing is deliberate with PARASORT.

Chapter 10. PARASORT

10.9

10.10

SyncSort for z/OS 1.2 Programmers Guide

Chapter 11. SyncSort DB2 Query Support

SyncSort can directly retrieve data from a DB2 database based on a user-provided query. An SQL SELECT statement is used to specify the criteria of the request. The query of the DB2 database replaces SyncSort's SORTIN or E15 processing. SORT or COPY functions, but not MERGE, can be used with DB2 queries. All SyncSort features performed after E15 processing are available for use with the DB2 query facility. Refer to Chapter 8. The Flow of the Sort for a summary of SyncSort's features and flow of control during processing. The SyncSort DB2 Query facility improves performance over DB2s DSNTIAUL program by allowing DB2 data to be passed directly into a SORT or COPY operation, without the use of setup steps or the need for user-written E15 exits.

Restrictions
The following cannot be used with the DB2 Query facility. If specified, they will cause SyncSort to terminate with a return code of 16: E15 exit The SKIPREC parameter The MAXSORT feature The PARASORT feature MERGE

Chapter 11. SyncSort DB2 Query Support

11.1

The following will be ignored if used with the DB2 Query facility: A SORTIN data set The TYPE parameter and the L1 and L2 values of the LENGTH parameter of a RECORD statement

Job Control Language


The JCL for the DB2 Query facility is similar to the JCL of a standard disk sort. The primary difference is that the DB2 query JCL must also contain an additional SORTDBIN DD specification to define the DB2 query with an SQL SELECT statement. To initiate a SORT or COPY with the DB2 Query facility using job control statements, specify PARM='DB2=dsn' on the EXEC statement. The dsn referred to in the DB2 parameter is the DB2 subsystem name to be accessed. When a SORT or COPY DB2 Query application is invoked from a program, specify the DB2 parameter in the $ORTPARM DD statement. Note: In order to issue the first query to the DB2 subsystem identified in the DB2=parm, you must have BINDADD authority so the plan can be added to the subsystem.

Sample EXEC Statement


The following shows a sample EXEC statement with the DB2 PARM:

PGM=SYNCSORT PGM=SORT //stepname EXEC PGM=IERRCO00 ,PARM='DB2=dsn' PGM=IGHRCO00 PGM=ICEMAN Figure 228. DB2 Query EXEC Statement

DD Statements
The DD statements used with the DB2 Query facility are summarized in the following table. Note that the SORTDBIN DD statement is unique to the DB2 Query facility. DB2 Query DD Statements //$ORTPARM //SYSIN DD DD Used to override PARM or control statement information. Control statement data set. Required unless the address of a 24bit or 31-bit extended parameter list is supplied by an invoking program.

11.2

SyncSort for z/OS 1.2 Programmers Guide

DB2 Query DD Statements //SYSOUT //SORTWKxx //SORTDBIN //SORTOUT DD DD DD DD Message data set. Required unless all messages are routed to console. Disk work area definition. Required unless DYNALLOC is specified. Data set which defines the DB2 query. Contains the SQL SELECT statement to be used for this application. Output data set. Required unless there is an E35. Ignored if the invoking program supplies an inline E35 exit routine; optional if the MODS statement activates an E35 exit routine. Output data set for records deleted by SUM. Required if XSUM parameter used. Required if user exits are in SYSIN and if user exits are to be linkage-edited at execution time.

//SORTXSUM //SORTMODS //SYSLIN //SYSLMOD //SYSUT1 //SYSPRINT //ddname

DD DD DD DD DD DD DD

Required for exits unless the exit is inline in LINKLIB/JOBLIB/ STEPLIB or in SYSIN. Table 41. DB2 Query DD Statements

SORTDBIN DD Statement
The SORTDBIN DD statement is required for a DB2 query application. The data set defined by the SORTDBIN contains the SQL SELECT statement that describes the criteria of the query. The SORTDBIN DD record format must be F or FB, and the record length must be 80. The SORTDBIN data set must be formatted in accordance with the following rules: Only a SELECT statement or $ELECT statement (for trial run described below) is accepted. Any other SQL statements will cause the job to terminate with a WER468A error message. For details on the facilities and syntax of a SELECT statement refer to the IBM publication DB2 Universal Database for OS/390 SQL Reference (GC26-9014). The maximum supported length of a SELECT statement for this feature is 32765 characters. The SELECT statement may not use the '--' convention of two consecutive hyphens to denote that the remainder of a card image is a comment. The SELECT statement may be terminated with a semicolon. Any characters found after the semicolon will be considered comments.

Chapter 11. SyncSort DB2 Query Support

11.3

Only columns 1 through 72 of each record will be read. Columns 73 through 80 will be ignored. Long fields (LONG VARCHAR and LONG VARGRAPHIC) and large object fields (BLOB, CLOB, and DBCLOB) are not supported. If they are specified, the application will terminate with a WER468A error message.

Operation
Using the query provided in the SORTDBIN data set, SyncSort will access the DB2 database specified in the DB2 EXEC PARM and will process as fixed-length records the rows returned from the query. The records will be processed as if read from a SORTIN or retrieved from an E15 exit. All SyncSort features available after E15 processing in the flow of control can be used with a SORT or COPY application. The record used within SyncSort is constructed from the fields in the query as follows: The order of the fields in the record is the same as the order specified by the SELECT statement. The data format of the fields within the record is the same format returned by DB2. A fixed-length field is the same length as returned by DB2. Variable-length character data is stored in a fixed-length field. The field length is equal to the maximum length of the field plus two bytes for a leading field length descriptor variable. The field length descriptor contains a binary value describing the number of bytes of data provided for this field. If an instance of the field is shorter than the maximum, the remaining bytes will be set to binary zeros. Any fields defined to allow nulls will cause the creation of two fields within the record constructed by SyncSort. The first will be the data field and the second will be a one byte indicator field. If the value of the field is null, by default the field will be filled with binary zeros (X'00') and the indicator field will contain a '?' to signify the field is null. If the value of the field is not null, the indicator will be set to binary zeros. If binary zeros would not be an appropriate fill value for a null field, use of SQL functions such as VALUE or COALESCE on the SELECT statement should be considered. For instance, if the field to be retrieved is packed decimal, it is usually best to create a null value of the proper PD format. This ensures that if the field is used later as a sort key or in other data conversion features, it would contain appropriate high or low values such as PD zeros or nines as specified in the VALUE or COALESCE function.

Record Description
Information about the record created by the query will be displayed in the SyncSort message data set. For each column selected, the report will display the start and end position

11.4

SyncSort for z/OS 1.2 Programmers Guide

within the record, the DB2 data type, the equivalent SyncSort data type, and whether null values are allowed. A data type whose length is not implied by the format will have a field length appended to its description. Note that the length displayed for a VARCHAR DB2 data type is two bytes shorter than would be indicated by the field start and end positions. The extra two bytes described in the start and end positions are for the field length descriptor, which is contained in the first two bytes of the field.

Record Description: Trial Mode Execution


When first developing an application, knowledge of the actual input record layout built from the query is required. This can be obtained from a trial mode execution. The trial mode execution uses a query provided in the SORTDBIN data set to generate a report of the input record layout in the SyncSort message data set (SYSOUT). The trial mode execution does not perform any other processing or request data from DB2. To request trial mode execution, modify the SQL SELECT keyword in the SORTDBIN data set to $ELECT. This indicates a trial mode execution is to be performed. For trial mode, execute SyncSort with JCL of the following form:
// EXEC PGM=SYNCSORT,PARM='DB2=DSN1' //STEPLIB DD DSN=DB2.SDSNLOAD,DISP=SHR // DD DSN=SORT.RESI.DENCE,DISP=SHR //SYSOUT DD SYSOUT=A //SORTDBIN DD * $ELECT FIRSTNME,LASTNAME,WORKDEPT,HIREDATE,EDLEVEL,SALARY FROM DSN.EMPTAB WHERE EDLEVEL>10

/* Figure 229. Sample JCL for Trial Mode Execution Note that only the SYSOUT and SORTDBIN DD are required for a trial mode execution. An actual execution of the application will require other DDs as documented for SORT or COPY applications. The STEPLIB DD statement specifies where the SyncSort and DB2 products can be found. The STEPLIB DD statement would be needed if these products could not be found in the standard system libraries. The DB2 EXEC statement parameter would be set to the DB2 subsystem name to be accessed. The SYSOUT data set will contain an input record layout report as shown in the following sample:

Chapter 11. SyncSort DB2 Query Support

11.5

SYNCSORT FOR Z/OS

1.2.0.0

U.S. PATENTS: 4210961, 5117495 Z/OS 1.1.0

(C) 2004 SYNCSORT INC.

DATE=2004/225

TIME=14.40.32

CPU MODEL 2064 LICENSE/PRODUCT EXPIRATION DATE: 31 MAR 2006

PRODUCT LICENSED FOR CPU SERIAL NUMBER 12345 DB2 QUERY OPTION SELECTED QUERY STATEMENTS: SELECT FIRSTNME,LASTNAME,WORKDEPT,HIREDATE,EDLEVEL,SALARY FROM DSN.EMPTAB WHERE EDLEVEL>10 INPUT RECORD DESCRIPTION:

COLUMN NAME ---------FIRSTNME LASTNAME WORKDEPT NULLINDICATOR HIREDATE NULLINDICATOR EDLEVEL NULLINDICATOR SALARY NULLINDICATOR

START POSITION -------1 15 32 35 36 46 47 49 50 55

END POSITION -------14 31 34 35 45 46 48 49 54 55

DB2 DATA TYPE -------------------VARCHAR(12) VARCHAR(15) CHAR(3)

SYNCSORT DATA TYPE --------CH CH CH CH

NULL VALUE

---------DISALLOWED DISALLOWED ALLOWED

DATE

CH CH

ALLOWED

SMALLINT

BI CH

ALLOWED

DECIMAL(9,2)

PD CH

ALLOWED

WER467I WER169I WER052I

DB2 QUERY TRIAL MODE SUCCESSFULLY EXECUTED RELEASE 1.1A BATCH 0999 TPF LEVEL 0 END SYNCSORT - JOBNAME,SORTSQL,,DIAG=E4FF,E28C,C888,6044,AC66,48A3,0E88,6E64

Figure 230. Sample SYSOUT You would create SyncSort control statements with field specifications based on the input record layout and place the control statements in the data set specified by the SYSIN DD statement. You would then create a set of JCL statements for the application.

11.6

SyncSort for z/OS 1.2 Programmers Guide

Sample SyncSort DB2 Query Application


In this example, a query is made for employee data. The example specifies how the application is to sort and format the data into a report. The formatting adds headers, field spacing, and converts a date to printable forms.
//SORTSQL EXEC PGM=SYNCSORT,PARM='DB2=DSN1' //STEPLIB DD DSN=DB2.SDSNLOAD,DISP=SHR // DD DSN=SORT.RESI.DENCE,DISP=SHR //SYSOUT DD SYSOUT=A //SORTOF1 DD DSN=OUT1,DISP=(NEW,CATLG),UNIT=3390,SPACE=(CYL,1) //SORTWK01 DD UNIT=SYSDA,SPACE=(CYL,20) //SORTWK02 DD UNIT=SYSDA,SPACE=(CYL,20) //SORTDBIN DD * SELECT FIRSTNME,LASTNAME,WORKDEPT,HIREDATE,EDLEVEL,SALARY FROM DSN.EMPTAB WHERE EDLEVEL>10 //SYSIN DD * SORT FIELDS=(3,12,CH,A) OUTFIL FILES=1, HEADER1=(2/,20:'EMPLOYEE INFORMATION', 2/,1:'FIRSTNAME',14:'LASTNAME',29:'WORKDEPT', 41:'HIRE DATE',54:'LEVEL',65:'SALARY', /,1:'---------',14:'--------',29:'---------', 40:'----------',54:'------',65:'---------'), OUTREC=(1:3,12,C' ',17,15,C' ',32,3,7C' ', 36,10,C' ',47,2,BI,M0,5C' ',50,5,PD,M2)

Figure 231. Sample SyncSort DB2 Query Application The following describes the JCL statements: The EXEC statement identifies SYNCSORT as the program to be executed. The DB2 PARM defines the DB2 subsystem to be accessed. The STEPLIB DD statement instructs the system as to where the SyncSort and DB2 products can be found. The SYSOUT DD statement assigns the SyncSort messages to the output device associated with SYSOUT class A. The SORTOF1 DD statement gives OUT1 as the output data set name and specifies a 3390 disk. One cylinder of primary space has been allocated on this volume. The DISP parameter shows that this data set is not yet in existence. The two SORTWK statements reserve space on four temporary data sets for intermediate storage. Twenty cylinders are to be reserved on the data sets.

Chapter 11. SyncSort DB2 Query Support

11.7

The SORTDBIN DD statement marks the beginning of the input stream that contains the SQL SELECT statement that describes the criteria of the query. The SYSIN DD statement marks the beginning of the input stream that includes the sort control statements. A sort will be performed and a report will be generated. The records read from the DB2 database under control of the query specified in the SORTDBIN data set will be formatted and presented in this report. Fields will be converted to printable format when necessary.

The SYSOUT will contain a report on the execution of the application. The report displays the control statements followed by the query record layout and SyncSort messages with information on the particular execution. The following is a sample report:

11.8

SyncSort for z/OS 1.2 Programmers Guide

SYNCSORT FOR Z/OS

1.2.0.0

U.S. PATENTS: 4210961, 5117495 Z/OS 1.1.0

(C) 2005 SYNCSORT INC. CPU MODEL 2064

DATE=2005/225

TIME=14.40.32

PRODUCT LICENSED FOR CPU SERIAL NUMBER 12345 SYSIN : SORT FIELDS=(3,12,CH,A) OUTFIL FILES=1, HEADER1=(2/,20:'EMPLOYEE INFOMATION', 2/,1:'FIRSTNAME',14:'LASTNAME',29:'WORK DEPT', 41:'HIRE DATE',54:'LEVEL',65:'SALARY', /,1:'---------',14:'--------',29:'---------', 40:'----------',54:'------',65:'---------'), OUTREC=(1:3,12,C' ',17,15,C' ',32,3,7C' ', 36,10,C' ',47,2,BI,M0,5C' ',50,5,PD,M2) DB2 QUERY OPTION SELECTED QUERY STATEMENTS: SELECT FIRSTNME,LASTNAME,WORKDEPT,HIREDATE,EDLEVEL,SALARY FROM DSN.EMPTAB WHERE EDLEVEL>10 INPUT RECORD DESCRIPTION:

LICENSE/PRODUCT EXPIRATION DATE: 31 MAR 2006

00048000 00049002 00050002 00051002 00052002 00053002 00054002 00060002 00070002

COLUMN NAME ---------FIRSTNME LASTNAME WORKDEPT NULLINDICATOR HIREDATE NULLINDICATOR EDLEVEL NULLINDICATOR SALARY NULLINDICATOR

START POSITION -------1 15 32 35 36 46 47 49 50 55

END POSITION -------14 31 34 35 45 46 48 49 54 55

DB2 DATA TYPE -------------------VARCHAR(12) VARCHAR(15) CHAR(3)

SYNCSORT DATA TYPE --------CH CH CH CH

NULL VALUE

---------DISALLOWED DISALLOWED ALLOWED

DATE

CH CH

ALLOWED

SMALLINT

BI CH

ALLOWED

DECIMAL(9,2)

PD CH

ALLOWED

WER110I WER110I WER124I WER045C WER405I WER211I WER449I WER246I WER054I WER169I WER052I

SORTOUT SORTOF1

: :

RECFM=FB RECFM=FBA

; LRECL= ; LRECL=

55; BLKSIZE= 27995 75; BLKSIZE= 27975

ESTIMATED PREALLOCATED/USED SORTWORK SPACE USAGE FACTOR = 600.00 END SORT PHASE SORTOF1 SYNCSMF : DATA RECORDS OUT 10; TOTAL RECORDS OUT 16

CALLED BY SYNCSORT; RC=0000

SYNCSORT GLOBAL DSM SUBSYSTEM ACTIVE FILESIZE 550 BYTES RCD IN 10, OUT 10

RELEASE 1.1A BATCH 0999 TPF LEVEL 0 END SYNCSORT - JOBNAME,SORTSQL,,DIAG=8CFF,4AD7,A09F,28FD,D572,68EB,A6C8,2462

Figure 232. Sample SYSOUT Report

Chapter 11. SyncSort DB2 Query Support

11.9

The following shows the output from the application:


EMPLOYEE INFOMATION

FIRSTNAME --------CHRISTINE CHRISTINE DIANE DIANE JOAN KEVEN MAGGIE MIKE PETER STEVE

LASTNAME -------HAAS MIKE HARISON HEMMINGER PAN MASK NEME BUSH MAWAH ARNEY

WORK DEPT --------A00 A00 A00 A00 A00 B00 A00 B00 B00 B00

HIRE DATE ---------01/01/1975 06/08/1978 02/01/1978 01/01/1975 05/01/1973 06/01/1988 06/01/1978 12/08/1987 02/01/1988 02/01/1990

LEVEL -----18 12 13 14 15 14 13 11 18 18

SALARY --------52,750.00 53,330.00 12,500.00 46,500.00 12,110.00 34,780.00 54,330.00 12,340.00 30,000.00 34,560.00

Figure 233. Sample Application Output

11.10

SyncSort for z/OS 1.2 Programmers Guide

Chapter 12. Tape Sort

When to Use Tape Sort


Traditionally, Tape Sort has been used where there is insufficient disk space for sort work. Currently, MAXSORT is the recommended sorting technique for large applications: (1) MAXSORTs disk SORTWK allocations can be defined independently of SORTIN size; (2) when a MAXSORT job is canceled for higher priority jobs, all previously produced data sets can be used without resorting; (3) all Disk Sort features and performance improvements are available with MAXSORT; (4) significantly less tape drive time is required; and (5) the job can be executed in segments to facilitate production scheduling.

Options Reserved to Disk Sort


These PARMs are reserved for sorts with SORTWK assigned to disk: BALANCE, BMSG, CMP=CPD/CLC, COMMAREA/NOCOMMAREA, CPU, DEBUG, DYNALLOC, ELAP, E15/ E35=COB, FILSZ=n, HBSI, HBSO, INCOR=ON/OFF, IO, LIST/NOLIST, NOIOERR, L6/ L7=n, PRINT121, NORC16, RELEASE=ON/OFF, RESET, RLSOUT, SDB=xxx, SKIPREC=n, STOPAFT=n, VLTEST=n/0, VLTESI=n/0, and all MAXSORT PARMs. Tape Sort will not validate decimal control fields, permit exits written in COBOL, C, or REXX, check the size of the input file after input processing, run incore, abend without a dump, optimize with HISTOGRM, issue the STIMER macro, adjust the message data sets DCB, release unused SORTWK or SORTOUT space, accept VSAM input, or stop processing after a specified number of records. Control statements and header line(s) appear with SYSOUT if Tape Sort is initiated through job control language; invoked Tape Sorts do not list sort control statements.

Chapter 12. Tape Sort

12.1

Invoked Tape Sorts may only use the 24-bit addressing mode. These control statements are reserved for sorts with SORTWK assigned to disk: MERGE, INCLUDE/OMIT, INREC, OPTION, OUTREC, OUTFIL, SUM, and ALTSEQ. In addition, the SORT statement does not permit COPY, DYNALLOC or FILSZ=n.

EXEC Statement
The Tape Sort EXEC statement differs from that for a Disk Sort in that the PGM=SYNCSORT coding cannot be used.

PGM=SORT PGM=IERRCO00 //stepname EXEC [,PARM='...'] PGM=IGHRCO00 PGM=ICEMAN Figure 234. Tape Sort EXEC Statement Format In addition, the set of PARMs is restricted to the following list.

PARM='

BALN OSCL POLY

n nK CORE , = MAX SIZE MAX-n MAX-nK n nK CORE , ( MAX ) SIZE MAX-n MAX-nK ,FLAG (I) ,FLAG (U) ,NOFLAG

,DIAG

,EQUALS ,NOEQUALS

,FILSZ=En

,IOERR=ABE

SYSOUT ,MSGDD= xxxxxxxx

,RC16=ABE '

Figure 235. Tape Sort PARM Parameter Format

12.2

SyncSort for z/OS 1.2 Programmers Guide

As usual, the PARM list is enclosed in single quotes. The BALN/OSCL/POLY PARM option is effective only with Tape Sort, where it specifies the balanced (BALN), oscillating (OSCL) or polyphase (POLY) sorting technique. It is recommended that this PARM value be omitted, permitting the sort to choose the technique best suited to the application.

DD Statements
Tape Sorts DD statements are summarized in the table below. They differ from Disk Sorts only in the additional requirement of a SORTLIB statement. SORTWKxx DD statements are required--Tape Sort is initiated by assigning these to tape. $ORTPARM is restricted to one 80-byte card image, which can include only PARMs. Tape Sort DD Statements //$ORTPARM //SYSIN //SYSOUT //SORTWKxx //SORTLIB //SORTIN DD DD DD DD DD DD Used to override PARM information. Restricted to one 80-byte card image. Control statement input data set. Required unless the invoking program supplies the address of a 24-bit parameter list. Message data set. Required. Assigned to tape. Required. Refers to tape sort library. Sort input data set. Required unless there is an E15. Ignored if the invoking program supplies an inline E15 exit routine; optional if the MODS statement activates an E15 exit routine. Sort output data set. Required unless there is an E35. Ignored if the invoking program supplies an inline E35 exit routine; optional if the MODS statement activates an E35 exit routine. Checkpoint data set. Required if Checkpoint-Restart is used. Required if user exits are in SYSIN and if user exits are to be linkage-edited at execution time.

//SORTOUT

DD

//SORTCKPT //SORTMODS //SYSLIN //SYSLMOD //SYSUT1 //SYSPRINT //ddname

DD DD DD DD DD DD DD

Library definition of user exits. Required unless exits are in LINKLIB. Table 42. Tape Sort DD Statements

SORTLIB DD Statement
The SORTLIB DD statement is required to reference the special tape sort program.

Chapter 12. Tape Sort

12.3

//SORTLIB

DD

DSN=SYNCTAPE,DISP=SHR Figure 236. Sample SORTLIB DD Statement

In this example, the tape sort modules are in a partitioned data set called SYNCTAPE. The modules will be used as needed by the Tape Sort control program which was given control by the operating system.

SORTWKxx DD Statement
Tape Sort is initiated by the use of tape devices for intermediate storage. Tape Sort requires a minimum of three SORTWKxx DD statements, numbered consecutively from 01. There may be as many as thirty-two sort work files, making 32 the largest possible nn value. Tape Sort uses 2400 and 3400 series tape units, including the 3480, 3490 and 3590 cartridge systems, with densities of 800 BPI, 1600 BPI, and 6250 BPI. Each reel of tape must be a full-size 2400-foot reel. It is possible to mix different densities or device types within the same sort, but SyncSort will use the lowest density to calculate the capacity of each SORTWK volume. If 3480 or 3490 IDRC tape drives are used, DCB=TRTCN=NOCOMP must be in effect. In Figure 237, the xxxx in the UNIT parameter represents the installation--specific name chosen to define a tape device.

2400 3400 //SORTWK01 DD UNIT= 3480 3590 xxxx Figure 237. SORTWKxx DD Statement Format for Tape Sorts

Calculating Tape SORTWK Requirements


The number of files needed for intermediate storage varies with the size of the input and the sorting technique used (BALN, OSCL or POLY). The table below indicates the minimum required for each of the three sorting techniques. This minimum figure is not the recommended number to use--allow more than the minimum number of drives to achieve sorting efficiency.

12.4

SyncSort for z/OS 1.2 Programmers Guide

Sorting Technique OSCL

Maximum No. Input Tapes 15

Minimum No. Tape Drives For SORTWKs

Maximum No. Tapes For SORTWKs

Note that...

(no. input vol- 17 umes + two) or four, whichever is larger. Two times (no. of input volumes + one). Three. 32

(1) An exact or a closely estimated SIZE on the SORT statement is necessary. (2) SORTIN and SORTWK tapes may not be mounted on the same drive. (1) An exact or a closely estimated SIZE is recommended. (2) Provide a generous amount of memory. POLY is always used, whether specified or not, when only 3 SORTWK tape drives are available. This technique is not recommended unless necessary.

BALN

15

POLY

17

Table 43.

Tape Sort Requirements

$ORTPARM DD Statement
When used in conjunction with Tape Sort, $ORTPARM can pass only PARM-coded information, and then only by way of a single 80-byte card image. $ORTPARM cannot be used to override control statements for Tape Sort. The following example changes three PARM options.

//$ORTPARM DD * CORE=128K,EQUALS,FILSZ=E15000 Figure 238. Sample Tape Sort $ORTPARM Data Set

Optimizing Tape Sort


Three factors are crucial to Tape Sort efficiency: a generous amount of intermediate storage, a closely estimated input size value on the SORT or EXEC statement, and the freedom to select the best sorting technique (BALN, OSCL or POLY) based on the nature of the application and conditions at execution time. Accordingly, the number of SORTWK data sets should be in excess of those suggested in the chart above, the BALN/OSCL/POLY PARM should be omitted and an accurate SIZE or FILSZ estimate should be provided.

Chapter 12. Tape Sort

12.5

Control Statements
Tape Sort supports only four control statements: SORT, RECORD, MODS and END. Of these four, only MODS and END are supported in their full Disk Sort version, and MODS is available only for JCL-initiated executions.

FIELDS = ( p 1, l 1, f 1, o 1, p 2 ,l 2, f 2 ,o 2 ,..., p 64 ,l 64 ,f 64 ,o 64 ) SORT FIELDS = ( p 1, l 1, o 1, p 2 ,l 2, o 2 ,..., p 64 ,l 64 ,o 64 ) ,FORMAT = f n ,SIZE = En ,EQUALS ,NOEQUALS [,FILSIZ = En] [,SKIPREC = n]

,CKPT CHKPT

Figure 239. SORT Control Statement Format for Tape Sort

F RECORD TYPE= ,LENGTH=(l 1 ,l 2 ,l 3 ,l 4 ,l 5 ) V Figure 240. Tape Sort RECORD Control Statement Format

MODS exit-name 1 = (r 1 b 1 [ d 1 ] ,N ) ... ,MODS exit-name 16 = (r 16 b 16 [ d 16 ] ,N ) ,S ,S Figure 241. MODS Control Statement Format

END Figure 242. END Control Statement Format

Exit Programs
With the exception of the merge input exit E32, all of the exits available for Disk Sort are supported for a JCL-initiated Tape Sort. When invoked, however, only E15 and E35 exits are available; these must be coded as subroutines of the calling program. The MODS statement is not supported for an invoked Tape Sort.

12.6

SyncSort for z/OS 1.2 Programmers Guide

Initiating Tape Sort Through JCL/Control Streams


//TAPESORT //STEPT //SORTLIB //MODLIB //SYSOUT //SORTIN // // // //SORTOUT // //SORTWK01 //SORTWK02 //SORTWK03 //SORTWK04 //SORTWK05 //SORTWK06 //SORTWK07 //SORTWK08 //SYSIN SORT RECORD MODS END * /* JOB EXEC DD DD DD DD 1 2 3 4 5 6

PGM=SORT DSN=TAPESORT.RESI.DENCE,DISP=SHR DSN=EXIT.E15,DISP=SHR SYSOUT=A DSN=INTAPE,UNIT=3480, VOL=SER=385678,DISP=(OLD,KEEP), DCB=(LRECL=100,RECFM=FB, BLKSIZE=900) DD DSN=OUT.TAPE,VOL=SER=783456, UNIT=3480,DISP=(NEW,KEEP) DD UNIT=TAPE DD UNIT=TAPE DD UNIT=TAPE DD UNIT=TAPE DD UNIT=TAPE DD UNIT=TAPE DD UNIT=TAPE DD UNIT=TAPE DD * FIELDS=(1,15,CH,A,16,8,BI,D), EQUALS,SIZE=E20000 TYPE=F,LENGTH=100 E15=(E15,550,MODLIB,N) END TAPE SORT MAY ACCOUNTS PROCESSED

7 8

9 10 11 12 13 14

Figure 243. Sample JCL/Control Stream 1. The JOB statement gives TAPESORT as the name of the job. 2. The EXEC statement identifies SORT as the program to be executed. 3. The required SORTLIB DD statement instructs the system to look for the Tape Sort secondary modules in the SORTLIB library under the data set name TAPESORT.RESI.DENCE. The DISP shows that this library may be shared. 4. The MODLIB DD statement defines the partitioned data set in which the exit routine resides. (Note that MODLIB is referenced in the MODS control statement.) The data set name of the exit library is EXIT.E15, and the DISP shows that the library may be shared.

Chapter 12. Tape Sort

12.7

5. The SYSOUT DD statement assigns the SyncSort messages to the output device associated with SYSOUT class A. 6. The SORTIN DD statement gives INTAPE as the input data set name, and specifies a 3480 tape unit with the volume serial number 385678. The DISP shows that the data set is already in existence. The DCB parameter shows in LRECL of 100 bytes, a fixed blocked RECFM, and a 900 byte BLKSIZE. 7. The SORTOUT DD statement gives OUT.TAPE as the output data set name, and specifies a 3480 tape unit with the volume serial number 783456. The DISP parameter shows that this data set is not in existence yet. The DCB parameter for the SORTOUT data set defaults to that of SORTIN. 8. The eight SORTWK DD statements indicate that 8 tapes are to be used for intermediate storage. 9. The SYSIN DD * statement marks the beginning of the system input stream that includes the program control statements. 10. The SORT control statement shows that two control fields are to be sorted on. The first begins on byte 1 of the record, is 15 bytes long, has character data, and is to be sorted in ascending order. The second begins on byte 16 of the record, is 8 bytes long, contains binary data, and is to be sorted in descending order. EQUALS requests that records with equal control fields leave the sort in the same order in which they came in. The SIZE parameter shows that the number of records in the input data set is estimated at 20,000. 11. The RECORD control statement shows that fixed-length records are being sorted. The LENGTH parameter shows 100 byte records at input, during the sort, and at output time. 12. The MODS control statement gives E15 as the exit-type. The name of the exit routine is also E15. It will take 550 bytes in main storage, and resides in a library defined on the MODLIB DD statement. (See the MODLIB DD statement.) The N indicates that linkediting has already been performed. 13. The END control statement marks the end of the control statements. A comment is given. 14. This is a comment statement. 15. The delimiter statement marks the end of the SYSIN input stream.

12.8

SyncSort for z/OS 1.2 Programmers Guide

Invoking Tape Sort from a Program


When initiating Tape Sort from a program, only certain parameters from the parameter list are processed The X'02' (MODS), X'04' (merge input files), X'05' (DEBUG), X'06' (ALTSEQ), X'07' (SUM), X'08' (INCLUDE/OMIT), X'09' (OUTREC), X'0A' (INREC), X'0B' (OUTFIL), X'F6' (ALTSEQ translation table), and X'F7' (User address constant) parameters are ignored. When invoked, Tape Sort supports only the E15 and E35 exits, which must be coded in line with the invoking program. REGISTER 1 ADDRESS OF POINTER Fullword Boundary X'80' POINTER (Fullword) Address of Parmlist Byte Count

Byte 1

Byte 2

Byte 3

Byte 4

Number of bytes in following list X'00' X'00' Required in order shown X'00' X'00' X'00' X'00' X'00' X'01' X'03' X'05' Beginning address of SORT statement Ending address of SORT statement Beginning address of RECORD statement Ending address of RECORD statement Address of E15 exit routine (zeros if none) Address of E35 exit routine (zeros if none) Main storage value Reserved main storage value Beginning address of message DD name to replace SYSOUT Beginning address of DEBUG statement (not processed) Ending address of DEBUG statement Optional X'FD' X'FE' X'FF' IMS flag Pointer to STAE work area (may code zeros if none) Message options (code in EBCDIC)

DIAG option (code in EBCDIC) BALN OSCL or PLY (code in EBCDIC) CRCX, PEER or LIST (not processed) DD name prefix to replace SORT in JCL (code in EBCDIC) Table 44. Tape Sort Parameter List

Chapter 12. Tape Sort

12.9

PTRWORD

PARMS

SORTBEG SORTEND RECBEG RECEND E15

E35

SORTERR

SORTOK

. . . LA LINK LTR BNZ B CNOP DC DC DS DC DC DC DC DC DC DC DC DC DC DC DC USING DS . . . USING DS . . . DS . . . BR DS . . . BR

1,PTRWORD Load address of pointer to parameter list EP=SORT Initiate tape sort 15,15 Test tape sort return code SORTERR Branch on error condition SORTOK Branch to normal processing 0,4 Fullword alignment for pointer X'80' Indicates pointer to parameter list AL3(PARMS) Address of parameter list H Unused first two bytes of first parameter Y(28) Byte count of remaining parameters A(SORTBEG) Beginning address of sort statement A(SORTEND) Ending address of sort statement A(RECBEG) Beginning address of record statement A(RECEND) Ending address of record statement A(E15) Address of E15 exit routine A(E35) Address of E35 exit routine C'DIAG' Turns on IOERR=ABE and RC16=ABE options C'SORT FIELDS=(19,6,PD,A,5,10,CH,A),EQUALS' Sort image begins C' ' Sort image ends C'RECORD TYPE=V,LENGTH=(104,,,64,84)' Record image begins C' ' Record image ends *,15 Using 15 as base register 0H Exit E15 has full responsibility for sort input

*,15 0H

Using 15 as base register Exit E35 has full responsibility for sort output

0H

Error routine for unsuccessful sort

14 0H

Return to invoking program Normal processing for successful sort

14

Return to invoking program

Figure 244. Sample Invoked Tape Sort In this example, Tape Sorts input file is provided by the in-line E15 exit routine. Since this causes the sort to ignore a SORTIN DD statement, the required RECORD control statement must include the LENGTH parameter. The RECORD statement specifies that the

12.10

SyncSort for z/OS 1.2 Programmers Guide

records to be sorted are variable in length, ranging from 64 to 104 bytes long at sort time, that the most frequent input record length is 84, and that the maximal length of 104 is not changed by the E35 exit routine; all length values include the Record Descriptor Words 4 bytes. The records are sorted in ascending numeric order by the packed decimal data in the 15th - 20th data bytes in the record. Records with equal numeric values in this field are further sorted by the character data in their first 10 data bytes, in ascending order. Records with equal control keys are passed to the E35 exit routine in the same order as they were generated by the E15 exit routine (the EQUALS parameter). The DIAG option is also set.

Chapter 12. Tape Sort

12.11

12.12

SyncSort for z/OS 1.2 Programmers Guide

Chapter 13. Performance Considerations

Disk Sort? MAXSORT? PARASORT? Tape Sort?


Disk Sort provides the current, established sorting technique, suitable for most sort/merge applications. Intermediate storage is allocated on disk devices and the sort size is limited by the allocated disk space plus secondary extents automatically obtained by the sort. MAXSORT, SyncSorts maximum capacity sorting technique, is not limited by disk space availability. MAXSORT determines how much data can be sorted using the available disk work space and divides SORTIN into SORTWK-manageable segments; the sorted segments are stored on tape, disk or MSS for a later, automatic merge. MAXSORT makes all the Disk Sort operational optimizing features and modern programming options available to large sorts, and additionally provides an enhanced breakpoint/restart capability for greater scheduling flexibility--the user can stop MAXSORT processing at selected intervals without loss of sorted output. PARASORT improves elapsed time performance for sorts whose input is read from a multivolume tape data set and/or concatenated tape data sets. The performance improvement from PARASORT is a result of processing the SORTIN input volumes in a parallel fashion. PARASORT requires two to eight times the current number of tape units, depending upon resource availability and the degree of improvement desired. PARASORT automatically manages the tape units and minimizes the use of the tape drive resources by deallocating excess tape drives during initialization and releasing all the extra units at the end of the sort input phase. By definition, Tape Sort uses tape for intermediate storage. This inhibits such state-of-theart sorting techniques as sophisticated disk I/O methods, high order merges, and modern

Chapter 13. Performance Considerations

13.1

parameter capabilities. For these reasons, MAXSORT performance is far superior to that of Tape Sort. MAXSORT is therefore the preferred method of handling all applications previously routed to Tape Sort. To convert a Tape Sort execution to MAXSORT, these changes must be made: Use the $ORTPARM DD statement to pass the MAXSORT PARM or (if the sort is initiated through JCL) add PARM='MAXSORT' to the EXEC statement. Allocate SORTWK files to disk (SORTWK requirements are independent of SORTIN size). Supply a SORTBKPT DD statement. Provide 2 or more SORTOUnn DD statements for the intermediate output and, if these are allocated to tape (as is usual), a SORTOU00 DD statement. If exits are included or the sort is invoked, supply a SORTCKPT DD statement in case restart should be necessary. (Optional.) Remove the SORTLIB DD statement.

Note that it may be necessary to supply additional memory in order to execute MAXSORT.

JCL Sorts vs. Program-Invoked Sorts


When SyncSort is initiated from a COBOL program, the calling program handles I/O, remains in core, and generally retards sort execution. SyncSort will yield maximum performance through proper synchronization of all data whenever it has control of the sorting process, i.e., whenever // EXEC PGM= SYNCSORT is used. From the point of view of performance, the JCL-initiated sort execution has the advantage. Whenever possible, tasks incidental to the sort/merge/copy process should be handled via SyncSort control statements. Where this is not possible, the JCL/control stream should be supplemented with user-written exit routines. Ideally, the exit routines exist as load modules, so that they do not require link-editing every time the job is run. SyncSort permits exit routines to be written in COBOL, C, FORTRAN, REXX, or Assembler language. If you must invoke the sort from a COBOL program, you may improve sort performance by passing an accurate FILSZ=n/En parameter via $ORTPARM.

Control Statement Issues


SyncSort control statements can be used to eliminate records from the input file (INCLUDE/OMIT), summarize and/or eliminate equal-keyed records (SUM), reformat records (INREC/OUTREC), set up multiple output files (OUTFIL) or write formatted reports (OUTFIL statement with HEADER, TRAILER, SECTIONS and OUTFIL parame-

13.2

SyncSort for z/OS 1.2 Programmers Guide

ters. These control statements provide a high performance alternative to the use of exits and invoking programs. The tasks they address are those which are most frequently executed and/or improve sort performance. Since sort throughput is in part a function of the number of bytes that are to be manipulated, considerable performance savings can result from using the INCLUDE/OMIT statement to eliminate irrelevant records; INCLUDE/ OMIT affects the data set prior to sorting/merging/copying. The SKIPREC and STOPAFT parameters are recommended for test runs of sorting applications for the same reason. When the file bias is high enough for a significant number of records to be summarized early in the sort, SUM will also provide performance gains if the XSUM option has not also been selected. When reformatting records, it is desirable to minimize the amount of data that must pass through the sort process. Other things being equal, INREC should be used to shorten records, OUTREC to lengthen them.

The Efficient Use of PARMs


There are four programming PARMs that may have a significant effect on sort performance: CMP, EQUALS, STOPAFT and SKIPREC. The CMP PARM specifies the kind of compare operation to be used for sort/merge control fields up to 16 bytes long, bearing the format code PD or ZD. When CMP=CPD, the default, is used, ZD fields are PACKed and then compared. Invalid PD data may cause a system 0C7 abend and program termination. The integrity of fields labelled ZD is only guaranteed when they contain valid ZD data. The delivered default of the VLTEST PARM supports CMP=CPD, as do certain other VLTEST PARM values. Whenever possible, set CMP= CPD for better sort performance. The alternative, CMP=CLC, is a more costly option--it forces the sort to extract potentially invalid PD and ZD fields and do a certain amount of data manipulation to obtain valid sign comparisons. The EQUALS PARM instructs the sort/merge to preserve the order of equal-keyed records. EQUALS will have a slight but generally significant impact on sort performance. By making EQUALS available on an individual sort basis, SyncSort makes this programming option available where it is needed, without imposing it on the installations more routine jobs. For sort efficiency, use EQUALS only where the preservation of the input order of equal-keyed records is important. The user interested in sort performance will specify the STOPAFT PARM in test runs of the sort. With STOPAFT=n, only the first n records of the input file will be sorted. By reducing the number of records to be processed, STOPAFT improves sort performance. If additional tests are necessary, the SKIPREC PARM can be used together with STOPAFT to select a different subset of the SORTIN data set.

Chapter 13. Performance Considerations

13.3

Optimizing System Resources


The efficiency of sort processing is measured in terms of the performance measures of CPU time, elapsed time, and I/O activity. Ordinarily, when SyncSort performs a sort, it seeks to balance these performance measures in a way that yields the best overall sort performance. It is possible, however, to define a particular performance measure as more important than others for a particular job. This can be done through SyncSorts Dynamic Storage Management (DSM) facility, which makes available four optimization modes for sort processing. These are BALANCE, CPU, ELAP and IO. BALANCE is the default optimization mode which provides the best overall balance between CPU time, sort elapsed time and I/O activity to SORTIN, SORTOUT and SORTWK. If CPU time is given the highest priority, SyncSort will minimize this resource at the expense of elapsed time and I/O activity. Selecting ELAP as the optimization mode will cause SyncSort to minimize the elapsed (wall clock) time of each sort, usually at some expense of the sorts CPU time. Likewise, if IO is selected as the optimization mode, SyncSort will minimize the I/O activity (EXCPs) performed by the sorts.

Setting CORE
The following examples illustrate the most common types of alternative codings for the CORE PARM: CORE=MAX-30K CORE=500K CORE=MAX From the perspective of memory management, there are three types of sort executions, requiring three different approaches to CORE coding: invoked sorts, JCL sorts with exit routines, and JCL sorts without exit routines. In the first case, where for example, a COBOL program calls SyncSort via the SORT verb, the sort and the invoking program (including its Input Procedure and Output Procedure) are all in memory at the same time. The only dynamic aspect to memory management in this case is the acquisition of memory for the buffers of any files opened by the Input and Output Procedures; it is only when a file is opened that the memory for the files buffers is obtained. Therefore, all data sets required during the sort should, if possible, be opened before invoking the sort. The coding of the CORE parameter must make allowances for the Input and Output Procedures file buffers by reserving enough memory for the greater of the two procedures requirements. If, for example, the Input Procedures files require 50K and the Output Procedures files require 100K, SyncSort should be instructed to set aside 100K for their use; code CORE=MAX-100K. If CORE=MAX is coded, it is likely that no memory will be available for buffers when the Input or Output Procedure attempts to open a file, resulting in an ABEND80A message. If CORE is coded with a constant value such as CORE=756K, there is still the possibility of an ABEND80A message since the constant value requested (in this

13.4

SyncSort for z/OS 1.2 Programmers Guide

case, 756K) may account for all the memory available, again leaving no memory for the buffers. With CORE=MAX-100K, the precise amount of memory used by the sort depends both on the amount of memory that is available and on the maximum value set at sort installation time (the site maximum). Since this form of the parameter ensures that 100K of the total memory available to this job will be set aside for the buffers, CORE=MAX-100K will not produce an ABEND80A message. Note that MAX-value must be greater than the minimum memory requirement for SyncSort execution. The table below illustrates the relationship between the site maximum and the available memory for an invoked sort requiring 100K bytes worth of buffers for the Input and Output Procedures. In reviewing the table, note that the site maximum sets an absolute ceiling on the amount of memory that can be used by the sort; even if additional memory is available, it is not available to the sort. This additional memory would, however, be available to the Input or Output Procedure for file buffers, accounting for some of the normal sort terminations indicated. Since the programmer has no way of knowing whether these conditions will hold at execution time, CORE=MAX-100K remains the preferred method of setting memory for an invoked sort with 100K bytes worth of buffers. The COBOL programmer has the option of setting CORE by means of the SORT-CORESIZE special register. In order to set memory aside for the buffers, the invoking program places a negative value into the special register prior to sort execution; CORE=MAX-100K is equivalent to MOVE-102400 TO SORT-CORE-SIZE. Under VS COBOL II or COBOL/ 370, CORE can be set by submitting the CORE=MAX-nK PARM via the $ORTPARM data set. Site Maximum Available Memory CORE= Memory used by the Sort MAX MAX MAX 756K 756K 756K MAX-100K MAX-100K MAX-100K MAX-100K 1024K 512K 1024K 756K 512K 756K 412K 412K 512K 260K Available for 100K Buffer Space Probable Sort Return Code

1024K 1024K 1024K 1024K 512K 1024K 1024K 512K 512K 1024K Table 45.

1024K 512K 2048K 900K 2048K 756K 512K 512K 1024K 360K

0 S80A - No core for buffers 0 S80A - No core for buffers 100K 0 100K 0 100K 0 0 S80A - No core for buffers 100K 100K 100K 100K 0 0 0 0 - Inefficient sort

Illustration: CORE Alternatives for Invoked Sort with 100K Buffer Space

When exits are included, the optimal coding of the CORE parameter depends on the memory value in the MODS control statement. As in the case of the COBOL Input/Output Procedure, coding CORE=MAX-100K will set aside 100K bytes for buffers. If the MODS

Chapter 13. Performance Considerations

13.5

statements memory value included sufficient buffer space, code CORE=MAX; coding anything but CORE=MAX nullifies the MODS memory value(s). Again, the site maximum prevents the sort from appropriating too much memory. When the exit program is not referenced in a MODS statement (e.g., when an E15/E35 exit routine is coded in line with an invoking Assembler program) or the MODS memory value accounts only for the programs code, memory must be reserved for the buffers of any files to be opened. An Assembler programs in-line E15/E35 exit routine is equivalent to a COBOL Input/Output Procedure. In JCL sorts without exit routines, it is not necessary to code any core parameter. SyncSort will use as much of the site maximum as is available at the time of execution. Thus, if the site maximum is set to 1024K and 2048K bytes are available, SyncSort will use 1024K.

The Incore Sort


Whenever there is sufficient memory, the standard Disk Sort may sort all the input data within its memory area, without writing to any of the work data sets that may have been provided. Sufficient memory, as discussed here, means that SyncSorts memory area/ address space is large enough to hold the SyncSort program, all of the input data, SORTIN or SORTOUT buffers (whichever are larger) and, if work data sets are allocated, SORTWKxx buffers. The incore sort is not available to Disk Sorts taking checkpoints, using SUM, OUTREC, OUTFIL, an E14 or E16 exit routine, or producing VSAM output.

When Can a Sort Run Entirely in Main Storage (No SORTWK Needed)?
An Incore Sort is possible when all of the data that is to be sorted can be contained in main storage. For most simple applications: Number of records that will fit in main storage =A-(B+C) D + 12 A = Memory available to SyncSort. B = 200K C = The greatest of: 2 X SORTIN block size, 2 X SORTOUT block size, and 15% of A. D = Average record length of data being sorted. Note: SORTWK data sets are required in order to use SUM, OUTREC, OUTFIL, a VSAM SORTOUT data set, checkpoint/restart, an E14 or E16 exit routine, MAXSORT or PARASORT.

13.6

SyncSort for z/OS 1.2 Programmers Guide

Disk Space Considerations


Tuning Disk Space Allocations
With the operational feature RELEASE turned ON (this is the delivered default), SyncSort automatically supplements and releases any disk space the user allocates for intermediate storage, making the allocation of the correct amount of SORTWK space an automatic, sortcontrolled process. For general sorting purposes, the user need not be concerned with precise SORTWK space allocations. However, allocating SORTWK space in cylinders, rather than blocks or tracks, will usually yield optimal performance. For best performance with filesizes greater than 30 megabytes, especially when DYNALLOC is not enabled, allocate the required space across 4 to 6 SORTWK devices. Message WER124I is provided in some applications in order to permit the user who is interested in a finely tuned sort execution to improve intermediate storage allocation for future runs. Routinely overallocating SORTWK, relying on RELEASE=ON, will delay sort step execution until all the space requested (including the excess space) is available, and will waste this excess space until its released at the end of Phase 1. Routinely underallocating by a large amount assumes that the needed storage will always be physically available. If, for some reason, the required storage cannot be obtained on any volume assigned for sort work areas, SyncSort will terminate with a SORT CAPACITY EXCEEDED error. A sort is considered to finely tuned when WER124I reports an overallocation factor between 1.00 and 1.50.

The Impact of Disk Space on the Work Data Sets on SyncSort


SyncSorts work data set disk space management is automated to a very high degree. It can: Automatically correct the underallocation of disk space by obtaining secondary allocations of disk space, as needed. This prevents costly SORT CAPACITY EXCEEDED terminations. Automatically release excess disk space at the completion of Phase 1. The space immediately becomes available for allocations to other jobs. Dynamically allocate work data sets through the z/OS DYNALLOC capability.

You can improve the efficiency of disk space usage by allocating optimally at the outset.

Disk Sort Intermediate Storage Calculation Formulas


Approximate Number of Tracks Required = A X B X 1.3 C

Chapter 13. Performance Considerations

13.7

where: A = Number of records to be sorted. B = Average record length of data being sorted. C = Track capacity of the work device: DEVICE TYPE 3380 3390 9345 TRACK CAPACITY IN BYTES 47,476 56,664 46,456

Allocating disk storage space in cylinders rather than tracks will improve the performance of SyncSort. When converting tracks to cylinders, round the number of cylinders up to the higher number. For example, if 9.5 cylinders are needed, allocate 10 cylinders.

Special Considerations Concerning SyncSorts Disk Space Management on Work Data Sets
SyncSort implements the automatic space management facility by reading the JFCB and modifying the SPACE parameter to enter a secondary allocation quantity (or accept one that was coded) and the RLSE subparameter. The JFCB is the z/OS control block that represents the DD statement. Several SyncSort options may be implemented which affect the disk space management of the sort. (See the Default Options chapter of the Installation Guide.) Specific functions of these features are as follows. 1. The automatic release of excess SORTWK space can be selectively suppressed. 2. The amount of secondary space per allocation can be modified. 3. The use of RLSE can be suppressed. 4. The use of space release is suppressed for small sorts, including the incore sort, in order to minimize system overhead. For non-incore sorts, if the file size is less than 4 megabytes, space release is normally suppressed. The 4 megabyte threshold may be altered. 5. The use of space release is normally suppressed for all invoked sorts to prevent SORT CAPACITY EXCEEDED termination when SyncSort is invoked more than once by a single program. If the first sort involves a modest volume of data, and causes space release to make the work data sets smaller, and the second sort is larger, the second sort might not find sufficient work space. Your installation can turn on space release for invoked sorts and thus save disk space. This very rarely causes problems because (1) few programs invoke the sort more than once and (2) SyncSorts automatic secondary allocation normally prevents a SORT CAPACITY EXCEEDED termination.

13.8

SyncSort for z/OS 1.2 Programmers Guide

6. SyncSort can routinely DYNALLOC data sets for every run. Other factors which may result in suppression of these features include: 1. Automatic release is suppressed for permanent data sets unless additional sort work space has been allocated. 2. Automatic release is normally suppressed by the installation for initiator-dedicated data sets. SyncSort uses normal z/OS facilities to obtain secondary allocations on work data sets. Consequently, the sort, like any other program under z/OS, is restricted to sixteen extents per data set. SyncSort, however, will recover from system B37 ABENDS that other programs might encounter in attempting secondary allocations. If SyncSort determines that a particular sort work data set cannot sustain a secondary allocation because it already has sixteen extents or because there is not enough space left on the volume, it does not attempt secondary allocation on that data set. SyncSort further checks all other work data sets, and if none of them can sustain a secondary allocation, it must abort with SORT CAPACITY EXCEEDED. SyncSort often avoids the use of one or more work data sets to minimize overall system conflict, as, for instance, between SORTIN and a work data set. It may obtain secondary allocation on some data sets while releasing on others.

The Coding and Use of Checkpoint-Restart


Occasionally, a hardware failure may prevent the successful completion of a sort or merge. Examples include a physically defective output volume or device, or a failure of the operating system for reasons unrelated to the sort. Since sorts tend to consume more system resources than any other type of application, it may be advantageous to be able to resume execution just before the failure occurred rather than restart the job at the beginning of the failed job step. SyncSort provides this restart capability through its support of the standard z/OS Checkpoint-Restart feature. To instruct SyncSort to take checkpoints, code CKPT or CHKPT (either spelling) on the SORT/MERGE control statement and supply a SORTCKPT DD statement. For a sort, checkpoints are taken at the beginning of Phase 3 before the output data sets (if any) are opened, and at every end-of-volume of a SORTOUT data set when OUTFIL is not in use. An operator may then restart the sort at Phase 3 or at any end-of-volume checkpoint. If necessary, a new output volume or device with identical characteristics to the defective volume or device may be substituted. For a merge or copy, SyncSort takes a checkpoint at every end-of-volume of a SORTOUT data set when OUTFIL is not in use. Checkpoints cannot be taken within a user exit routine.

Chapter 13. Performance Considerations

13.9

The DISP Parameter for SORTCKPT, SORTWKxx and SORTOUT Data Sets
The coding of the DISP parameter for these data sets depends in part on the PARM-specified response to an unsuccessful sort. There are four cases: NOIOERR and NORC16 (These are the delivered defaults.) IOERR=ABE and RC16=ABE IOERR=ABE and NORC16 NOIOERR and RC16=ABE

When return code 16 is issued by the unsuccessful sort (i.e., when an I/O error occurs and NOIOERR is set or, for other errors, when NORC16 is set), the second subparameter of the DISP parameter should be specified as KEEP or CATLG. When the unsuccessful sort causes a user abend (i.e., when IOERR=ABE for I/O errors, RC16=ABE for other errors), the third subparameter of the DISP parameter should be specified as KEEP or CATLG. Thus, with NOIOERR and RC16=ABE or with IOERR=ABE and NORC16, both the second and the third DISP subparameter should be specified as KEEP or CATLG. Unless the DISP parameter is coded in accordance with these two PARM values, restart will be impossible. It is recommended that these data sets be deleted upon successful completion of the sort. This can be done by coding the COND parameter for an IEFBR14 step to follow the sort step in the jobstream. The COND parameter makes the IEFBR14 (data set deletion) execution depend upon the successful completion of the previous step (the sort).

The SORTCKPT Data Set


Assign a permanent DSN to the SORTCKPT DD statement and specify the UNIT, SPACE and VOL=SER parameters to make the operators job easier should a deferred restart become necessary.

//SORTCKPT // //

DD

UNIT=3390,DSN=SORT.CKPT, SPACE=(CYL,(1,1)), VOL=SER=WORK01,DISP=(MOD,KEEP,KEEP)

Figure 245. Sample SORTCKPT DD Statement

The SORTWKxx Data Set(s)


Assign a permanent DSN to every SORTWKxx DD statement and specify the UNIT, SPACE and VOL=SER parameters in case a deferred restart becomes necessary. Avoid using passed data sets, JCL refer-backs, and any other references which would make the JCL following the restart dependent on the JCL preceding the restart.

13.10

SyncSort for z/OS 1.2 Programmers Guide

Note that the SORTCKPT data set and the SORTWKxx data set(s) may reside on the same direct access device without loss of efficiency.

//SORTWK01 // //

DD

UNIT=3390,DSN=SORT.WK01, SPACE=(CYL,(20,10)), VOL=SER=WORK02,DISP=(,KEEP,KEEP)

Figure 246. Sample SORTCKPT DD Statement

Automatic Checkpoint-Restart
With automatic checkpoint-restart, the operating system will ask the operator whether an unsuccessful/abending step should be restarted. A yes reply instructs the system to restart the job at the last checkpoint taken. If the operator replies no, the job will still be eligible for deferred checkpoint-restart, but its control statements will have to be modified before the job is resubmitted. The requirements for automatic checkpoint-restart are: The sort step must have a unique name. The JOB statement must specify RD=R and MSGLEVEL=1. All system completion codes with which the sort may abend should be defined at system generation time as being eligible for restart. If the RC16=ABE and/or IOERR=ABE options are in effect, for example, then user abend codes 16 and/or 999 must be eligible for restart. User-written exit routines and calling programs may not issue the STIMER macro.

Chapter 13. Performance Considerations

13.11

//AUTOCKPT // //XVISORT // //SYSOUT //SORTIN //SORTOUT // //SORTWK01 // // //SORTWK02 // // //SORTCKPT // // //SYSIN SORT /*

JOB

(1101,2333),P.ARBEAU,RD=R, MSGLEVEL=(1,1) EXEC PGM=SORT, PARM='RC16=ABE,IOERR=ABE' DD SYSOUT=A DD DSN=XVI.SORTIN,DISP=OLD DD UNIT=TAPE,DISP=(,CATLG,KEEP), DSN=XVI.SORTOUT DD UNIT=3390,DISP=(,DELETE,KEEP), VOL=SER=WORK01,DSN=XVI.SORTWK01, SPACE=(CYL,40) DD UNIT=3390,DISP=(,DELETE,KEEP), VOL=SER=WORK02,DSN=XIV.SORTWK02, SPACE=(CYL,40) DD UNIT=3390,DISP=(,DELETE,KEEP), VOL=SER=WORK02,DSN=XVI.SORTCKPT, SPACE=(CYL,(1,1)) DD * FIELDS=(1,10,CH,A),CKPT

Figure 247. Sample Automatic Checkpoint-Restart JCL Stream

Deferred Checkpoint-Restart
Unlike automatic checkpoint-restart, deferred checkpoint-restart requires that certain JCL changes be made before resubmitting the job. The requirements for a deferred restart are: A SYSCHK DD statement must appear immediately before the first EXEC statement in the job. The SYSCHK DD must use the same DSN name as the SORTCKPT DD of the sort that failed. Specify UNIT, VOL=SER, and DISP=(OLD,KEEP). The RESTART parameter must be specified, and must provide the job stepname and the PROC stepname (if any) associated with the step containing the failed sort, as the first subparameter. (Separate the two stepnames by a period.) The second subparameter should contain the checkpoint ID of the last checkpoint taken before the sort failed. This can be determined from the console messages given for the job. For JCL sorts, the ID is usually "Cnnnnnnn," referring to the sequence number assigned by the operating system. SORTIN and SYSIN DD DUMMY statements are permissible if the program is being restarted at a point where they are no longer needed.

13.12

SyncSort for z/OS 1.2 Programmers Guide

//DEFCKPT // // //SYSCHK // // //XVISORT // //SYSOUT //SORTIN //SORTOUT // //SORTWK01 // // //SORTWK02 // // //SORTCKPT // // //SYSIN

JOB

DD

EXEC DD DD DD DD

DD

DD

DD

(5433,2333),PAT.TAIG.NANT, RD=R,MSGLEVEL=(1,1), RESTART=(XVISORT,C0000001) UNIT=3390,DISP=(OLD,KEEP), VOL=SER=WORK02, DSN=XVI.SORTCKPT PGM=SORT, PARM='RC16=ABE,IOERR=ABE' SYSOUT=A DUMMY UNIT=TAPE,DISP=(,CATLG,KEEP), DSN=XVI.SORTOUT UNIT=3390,DISP=(OLD,DELETE,KEEP), VOL=SER=WORK01,DSN=XVI.SORTWK01, SPACE=(CYL,40) UNIT=3390,DISP=(OLD,DELETE,KEEP), VOL=SER=WORK02,DSN=SVI.SORTWK02, SPACE=(CYL,40) UNIT=3390,DISP=(MOD,DELETE,KEEP), VOL=SER=WORK02,DSN=XVI.SORTCKPT, SPACE=(CYL,(1,1)) DUMMY

1 1 1 1

Figure 248. Sample Deferred Checkpoint-Restart JCL Stream 1. This JCL differs from automatic checkpoint-restart JCL.

Optimizing Data Set Placement


The Impact of Work Devices on SyncSort
The performance of SyncSort is almost totally independent of the number of work data sets. The sorts performance may, however, be strongly influenced by the number of devices to which the work data sets are allocated. Generally, for any sort of significant size, the more work devices, the better the sort can perform. If the sort file size is small, however, performance improvements might be outweighed by increased overhead in managing the extra data sets. Increasing the number of work devices will: 1. Improve the overlap between CPU and I/O processing. 2. Improve the effectiveness of SyncSorts integrated activity monitoring. 3. Reduce the likelihood of SORT CAPACITY EXCEEDED.

Chapter 13. Performance Considerations

13.13

Increasing the number of data sets without increasing the number of devices will only increase overhead. It is suggested that, as an initial standard, you implement: 1. Four work devices if file size > 100 MB (megabytes). 2. Three work devices if 100MB > file size > 10MB. 3. Two work devices if 10 MB > file size > 1 MB. 4. One work device if file size < 1MB. In all cases, allocate one work data set per work device.

Obtaining Device Separation


The easiest way to increase the number of work devices is to increase the number of work data sets. This tends to increase the number of devices to which work data sets allocate, although the relationship between the two may be complex and unpredictable. Try to ensure that every sort has at least one work data set on a pack that does not contain SORTIN or SORTOUT. SyncSort will avoid work data set contention with SORTIN and SORTOUT if it can.

Channel Separation
Try to obtain as many paths to the work devices as possible. It is particularly desirable to provide some path to the work data sets that will not be jammed with traffic from SORTIN or SORTOUT. On the other hand, SORTIN and SORTOUT may be on the same channel, or even the same device, without any performance loss.

Device Type Considerations


Avoid using a mixture of device types with different track capacities for the work data sets, since SyncSort sacrifices some efficiency if this is the case. If you must choose between two different disk device types for the work data sets, use the faster; if they are close in speed, use the one with the larger track size. Avoid the use of VIO data sets for work data sets. If you must use tape work data sets, allocate as many as possible.

13.14

SyncSort for z/OS 1.2 Programmers Guide

Chapter 14. The HISTOGRM Utility Program

What Is HISTOGRM?
HISTOGRM is a separate program which is used to gain information about variable-length files. The program scans a variable-length file and provides information which can then be used to run more efficient sorts. HISTOGRM can report the: Block count for minimum and maximum block lengths Record count for minimum and maximum record lengths Average record length Total number of bytes in the file Total number of blocks in the file L6 value (average work space) for variable-length records L7 value (segment length) for variable-length records

HISTOGRM can be used to analyze variable-length records in a VSAM entry-sequenced or key-sequenced data set. When HISTOGRM processes a VSAM file only record information is gathered; block statistics are not produced.

Chapter 14. The HISTOGRM Utility Program

14.1

Using HISTOGRM to Determine L6 and L7 Values for SyncSort


The L6 and L7 values HISTOGRM calculates are passed to SyncSort via the L6, L7 PARM options or the l6, l7 values in the LENGTH parameter of the RECORD control statement. (When there is a conflict, the PARM specification takes precedence.) These values are ignored in a merge or copy application.

Control Parameters for HISTOGRM


The control parameters are outlined below; defaults are underlined. To specify other values, include a control statement in the SYSIN DD portion of the job control stream. Parameters may appear anywhere through column 71, provided they are separated by commas with no intervening blanks.

NRECS
ALL NRECS= nnn Tells how many records to scan in the variable-length file.

WIDTH
20 WIDTH= nnnn Indicates the range between minimum and maximum block lengths and the minimum and maximum record lengths in each group of the HISTOGRM output. The number specified for the WIDTH value must be a multiple of 4. (4, 8, 12, . . . See examples of block and record HISTOGRMs that follow.) Adjust this range based on the characteristics of the file (the lengths of the shortest and longest record) and the desired length of HISTOGRM.

DEVWK

3380 DEVWK= 3390

Tells the type of disk device that will be used for intermediate storage when the sort is run. Specify the device number if HISTOGRM is to calculate L6 and L7.

14.2

SyncSort for z/OS 1.2 Programmers Guide

KEYL
20 KEYL= nnnn Gives the end location of the last control field in the record. Specify a value for KEYL if HISTOGRM is to calculate L6 and L7.

BIGREC
20 BIGREC= nnnn MAX Specifies the maximum number of HIS025I messages that will be issued in a HISTOGRM execution. When HISTOGRM processes a large file, this message may be generated as often as once for each record in the file. BIGREC limits the number of HIS025I messages that will be issued in each execution. HISTOGRM processing continues, but no further messages are issued once the BIGREC value is reached.

BLOCK
BLOCK NOBLOCK

Tells whether or not to print the graphic portion of the HISTOGRM for block length.

REC
REC NOREC

Tells whether or not to print the graphic portion of the HISTOGRM for record length.

Chapter 14. The HISTOGRM Utility Program

14.3

BIGSTOP
BIGSTOP NOBIGSTP

Tells whether or not to terminate the HISTOGRM run if an RDW value greater than the DCB LRECL is encountered in the input file.

Job Control Language


The following example shows a sample execution of HISTOGRM. 1. SYSUT1 is the variable-length file to be scanned. Specify the DCB parameter if

//L6L7 //STEP1 //STEPLIB //SYSUT1 //

PGM=HISTOGRM DSN=HISTOGRM,DISP=SHR UNIT=3490,VOL=SER=000001, DSN=VLRECS,LABEL=(1,SL), DISP=OLD //SYSPRINT DD SYSOUT=A //SYSIN DD * KEYL=50,DEVWK=3390,NOBLOCK,NOBIGSTP /* Figure 249. Sample JCL/Control Stream for HISTOGRM SYSUT1 is a non-standard label tape.

JOB EXEC DD DD

2 3

2. SYSPRINT is the data set on which printed output will appear. The DCB (not illustrated) is: DCB=(LRECL=121,BLKSIZE=121,RECFM=F). 3. You may use DD DUMMY instead of SYSIN DD *. Specify //SYSIN DD DUMMY,DCB=(LRECL=80,RECFM=FB,BLKSIZE=80).

Executing HISTOGRM through an E15 Exit


It is possible to execute HISTOGRM during a sort by specifying an E15 exit in the MODS control statement and coding HISTE15 as the r value. This produces a printout of the HISTOGRM for Records at the conclusion of the job. (It is, however, not possible to get a printout of the HISTOGRM for Blocks when initiating HISTOGRM in this way.)

14.4

SyncSort for z/OS 1.2 Programmers Guide

The following example shows a sample execution of HISTOGRM by an E15 exit during a sort.

//HISTSORT //STEP2 //SORTIN // // //SORTOUT // // //SORTWK01 //SORTWK02 //SORTWK03 //SYSOUT //MODLIB //SYSIN SORT MODS //SYSPRINT //HISTIN WIDTH=40 /*

JOB EXEC DD

PGM=SYNCSORT UNIT=3490,VOL=SER=000001, DSN=VARDATA,LABEL=(1,SL), DISP=OLD DD UNIT=3490,VOL=SER=000002, DSN=SORTED.DATA,LABEL=(1,SL), DISP=(,KEEP) DD UNIT=SYSDA,SPACE=(CYL,(20,10)) DD UNIT=SYSDA,SPACE=(CYL,(20,10)) DD UNIT=SYSDA,SPACE=(CYL,(20,10)) DD SYSOUT=A DD DSN=SYS1.SYNCLIB,DISP=SHR DD * FIELDS=(4,10,CH,A) E15=(HISTE15,7400,MODLIB,N) DD SYSOUT=A DD *

4 5 6 7 8 9

Figure 250. Sample JCL/Control Stream for HISTOGRM Initiated by an E15 Exit 1. SORTIN is a DD statement for SyncSort. It contains the data set that will be analyzed and then sorted. The data set name is VARDATA, and it is found on the standard labeled tape with the volume serial number 000001. The data set is already in existence. If SORTIN is not a standard label tape, DCB parameters must be specified. Note that RECFM must be either V, VB, or VBS. 2. SORTOUT is a DD statement for SyncSort. It assigns the data set name SORTED.DATA to the output file, and specifies a 3490 tape unit with the volume serial number 000002. It is not yet in existence. The DCB parameters default to those of SORTIN. 3. SORTWK01, SORTWK02, and SORTWK03 are DD statements for SyncSort. They reserve 20 cylinders of primary space, 10 cylinders of secondary space on direct access devices for intermediate storage. 4. SYSOUT is a DD statement for SyncSort. It assigns the SyncSort messages to the output device associated with class A. 5. The MODLIB DD statement is used to define the partitioned data set in which the HISTE15 program resides; MODLIB is referenced in the MODS control statement. The data set name is SYS1.SYNCLIB, and the DISP shows the library may be shared.

Chapter 14. The HISTOGRM Utility Program

14.5

6. The SYSIN DD * statement marks the beginning of the input stream that includes the sort control statements. The SORT control statement shows that one control field will be sorted on. It consists of bytes 4-13 of the record, contains character data, and is to be sorted in ascending order. The MODS control statement must specify an E15 exit as an exit-type parameter and give HISTE15 as the exit routine name. HISTE15 takes 5000 bytes of core storage and resides in the main SyncSort library referenced here by a DD statement named MODLIB. The routine does not require link-editing during sort execution. 7. SYSPRINT is the data set on which the printout from HISTE15 appears. Its DCB is: DCB=(LRECL=121,BLKSIZE=121,RECFM=F). 8. The HISTIN DD statement is optional. It is used to override any default values. The following DCB parameter must be specified: DCB=(LRECL=80,RECFM= FB,BLKSIZE=80). (With HISTIN DD *, the DCB is not necessary.) Defaults for HISTE15 NRECS= WIDTH= DEVWK= KEYL= BIGREC= NOBLOCK REC NOBIGSTP (This cannot be overridden.) ALL 20 The same SORTWK devices used in executing this sort. End of key field furthest into record for this sort. 0 (This cannot be overridden.) (This cannot be overridden.)

14.6

SyncSort for z/OS 1.2 Programmers Guide

HIS007I HIS008I HIS009I BLOCK LENGTH MIN MAX 40 60 80 100 120 140 59 79 99 119 139 159

NUMBER OF BLOCKS................. TOTAL LENGTH OF ALL BLOCKS....... AVERAGE BLOCK LENGTH.............

898 104119 116

BLOCK COUNT

18 80 145 205 253 197

.......................................................................................... .****** . .************************** . .************************************************ . .******************************************************************** . .************************************************************************************ . .***************************************************************** . ..........................................................................................

yyyyyyyyyyy

cbddbdbdbdbdbdbdbffgfg

Sample Contents of HISTOGRM Output

1. HISTOGRM informational messages for blocks are printed at the top of the report. For explanations, see individual messages in the message section which follows these examples.

2. BLOCK COUNT gives the number of blocks falling within the minimum and maximum numbers shown as BLOCK LENGTH. The range is the WIDTH value that has been specified.

Chapter 14. The HISTOGRM Utility Program

3. The asterisks are the graphic representation of the number of blocks within the range of block lengths.

14.7

14.8
952 93412 98 50 129 72 20 155 40 48 41 3390 RECORD LENGTH MIN MAX 40 60 80 100 120 140 59 79 99 119 139 159

HISO10I HISO11I HIS012I HIS016I HIS015I HIS014I HIS017I HIS018I HISO19I HIS005I HIS023I HIS020I

NUMBER OF RECORDS.............. TOTAL LENGTH OF ALL RECORDS.... AVERAGE RECORD LENGTH.......... KEY LENGTH..................... AVERAGE SPACE PER RECORD - L6.. RECOMMENDED SEG. SIZE - L7..... LINE WIDTH..................... LONGEST RECORD................. SHORTEST RECORD................ RECORDS TOO LONG............... RECORDS TOO SHORT.............. DEVICE TYPE....................

RECORD COUNT ......................................................................................... 104 .********************************** . 181 .************************************************************ . 199 .***************************************************************** . 196 .**************************************************************** . 211 .********************************************************************* . 61 .******************** . .........................................................................................

SyncSort for z/OS 1.2 Programmers Guide Sample Contents of HISTOGRM Output

1. HISTOGRM informational messages for records are printed at the top of the report. For explanations, see individual messages in the message section which follows these examples.

2. RECORD COUNT gives the number of records falling within the minimum and maximum numbers shown as RECORD LENGTH. The range is the WIDTH value that has been specified.

3. The asterisks are the graphic representation of the number of records within this range of record lengths.

HISTOGRM Messages
HISnnnA messages indicate a critical error condition. HISTOGRM terminates to allow you to correct the error(s) so that a successful program may be run. messages are informational or indicate a non-critical error. They are printed on the HISTOGRM output for blocks and records and contain statistical information inserted by HISTOGRM. INVALID CONTROL CARD EXPLANATION: A blank control statement or an incomplete control parameter was found. INVALID DATA ON CONTROL CARD EXPLANATION: An invalid control parameter was found. EXPECTED CONTIN NOT FOUND EXPLANATION: A control statement continuation was indicated either by a non-blank character in column 72 or by a comma immediately after the last control field, but no continuation card image was found. INVALID DCB OR ACB DATA EXPLANATION: The SYSUT1 data set was opened and one of three errors was detected: (1) LRECL was not specified, (2) BLKSIZE was not specified, (3) RECFM was not V, VB, or VBS, or (4) the data set is a VSAM RRDS. ACTION: Check for a missing DCB parameter if SYSUT1 is a nonstandard label tape. If the file is a standard label tape or a disk file, one of the DCB subparameters may be missing, or the file is not a variable-length file. RECORDS TOO LONG nnnn EXPLANATION: Records with lengths exceeding the length specified in the DCB were found. The nnnn represents the number of long records found. Long records have no effect on other HISTOGRM statistics. INVALID SPAN CONTROL FIELD BLOCK nnnn LOGICAL RECORD nnnn {DATA SET # nnnn} EXPLANATION: The third byte of the four byte record descriptor word preceding a variable-length record does not contain a valid code X'00', X'01', X'10', X'11', or the code is inconsistent with the code of the previous segment. The block and record number being processed are included in the message text. The first 100 bytes of both current and previous segment along with their RDWs, follows

HISnnnI

HIS001A

HIS002A

HIS003A

HIS004A

HIS005I

HIS006A

Chapter 14. The HISTOGRM Utility Program

14.9

this message. DATA SET # will be the concatenation number within SYSUT1 if the input data set is concatenated. HIS007I NUMBER OF BLOCKS nnnn EXPLANATION: The total number of blocks read from the SYSUT1 data set is given on the HISTOGRM for blocks. TOTAL LENGTH OF ALL BLOCKS nnnn EXPLANATION: The total length in bytes of all blocks read is given on the HISTOGRM for blocks. AVERAGE BLOCK LENGTH nnnn EXPLANATION: The average block length of all blocks read is given on the HISTOGRM for blocks. NUMBER OF RECORDS nnnn EXPLANATION: The total number of records read from the SYSUT1 data set is given on the HISTOGRM for records. The total will exclude any records with lengths greater than the length specified in the DCB. TOTAL LENGTH OF ALL RECORDS nnnn EXPLANATION: The total length in bytes of all records read is given on the HISTOGRM for records. AVERAGE RECORD LENGTH nnnn EXPLANATION: The total length of all records is divided by the number of records and the quotient is given on the HISTOGRM for records. NUMBER OF SPANNED RECORDS EXPLANATION: The number of records contained within two or more blocks is given on the HISTOGRM for records. RECOMMENDED SEG. SIZE - L7 EXPLANATION: The recommended segment size is given on the HISTOGRM for records. Supply SyncSort with this value either through L7 in the PARM field of the EXEC statement or through l7 in the LENGTH parameter of the RECORD control statement. Note: If the recommended number is 0, the range of record lengths in the file was too wide to compute an optimal value. In this case, do not supply an L7. HIS015I AVERAGE SPACE PER RECORD - L6 EXPLANATION: The average work space necessary for each record is given on the HISTOGRM for records. Supply SyncSort with this value either through L6 in the PARM field of the EXEC statement

HIS008I

HIS009I

HIS010I

HIS011I

HIS012I

HIS013I

HIS014I

14.10

SyncSort for z/OS 1.2 Programmers Guide

or through l6 in the LENGTH parameter of the RECORD control statement. Note: If the recommended number is 0, the range of record lengths in the file was too wide to compute an optimal value. In this case, do not supply an L6. HIS016I KEY LENGTH nnnn EXPLANATION: The end location of the last control field in the record is given on the HISTOGRM for records. LINE WIDTH nnnn EXPLANATION: The numeric interval between the minimum and maximum block/record length is given on the HISTOGRM for records. LONGEST RECORD nnnn EXPLANATION: The length of the longest record read; that is the record containing the largest value in the record descriptor word. INVALID DEVICE TYPE EXPLANATION: An invalid device type was specified on the control statement in the SYSIN data set. SHORTEST RECORD nnnn EXPLANATION: The length of the shortest record read is given on the HISTOGRM for records. DEVICE TYPE nnnnnn EXPLANATION: The type of intermediate storage device to be used for the sort is given on the HISTOGRM for records. BLOCK PARAMETER IGNORED EXPLANATION: Information about blocks cannot be collected when running HISTE15 during a sort. INPUT FILE IS EMPTY EXPLANATION: There are no records in the input file which are not longer than the data sets LRECL. RECORDS TOO SHORT nnnn EXPLANATION: Records with lengths less than the KEYL value specified for the HISTOGRM execution were found. The nnnn is the number of short variable-length records in the file. LRECL nnnnn,BLKSIZE nnnnn,RECFM xxx EXPLANATION: The logical record length, block size, and record

HIS017I

HIS018I

HIS019A

HIS019I

HIS020I

HIS021I

HIS022A

HIS023I

HIS024I

Chapter 14. The HISTOGRM Utility Program

14.11

format of the input data set obtained from the SYSUT1 DCB after OPEN. HIS025A INVALID RDW/RECORD LENGTH BLOCK nnnn LOGICAL RECORD nnnn {DATA SET # nnnn} EXPLANATION: The RDW value of the current record is greater than the DCB LRECL and HISTOGRM has been requested to terminate (thru the BIGSTOP parameter). The block and record number are supplied in the message and the first 100 bytes of the record and the RDW follow the message. DATA SET # will be the concatenation number within SYSUT1, if the input data set is concatenated. INVALID RDW/RECORD LENGTH BLOCK nnnn LOGICAL RECORD nnnn {DATA SET # nnnn} EXPLANATION: The RDW value of a record is greater than the DCB LRECL. Block number and record number are supplied in the message text, along with the concatenation number if SYSUT1 is concatenated. INPUT DATA SET IS VSAM ... NO BLOCK STATISTICS GATHERED EXPLANATION: The input to HISTOGRM is a VSAM data set; therefore block statistics are not produced for this HISTOGRM execution. SYSUT1 DD STATEMENT MISSING EXPLANATION: The input data set is absent; the HISTOGRM run has terminated. VSAM LOGICAL ERROR nn EXPLANATION: An error occurred while reading a VSAM data set. For the definition of the error number, nn, consult one of the following IBM publications: HIS029A DFSMS/MVS Macro Instructions for Data Sets, SC26-4913

HIS025I

HIS026I

HIS027A

HIS028A

VSAM OPEN ERROR nn EXPLANATION: An error occurred during an attempt to OPEN a VSAM file. For the definition of the error number, nn, consult one of the following IBM publications: DFSMS/MVS Macro Instructions for Data Sets, SC26-4913

HIS030A

message text EXPLANATION: An I/O error has occurred. The message text gives a detailed description of the error.

14.12

SyncSort for z/OS 1.2 Programmers Guide

HIS031A

INVALID BDW ENCOUNTERED BLOCK nnnn EXPLANATION: The block descriptor word for block number nnnn, was either zero or greater than the DCB blocksize.

Chapter 14. The HISTOGRM Utility Program

14.13

14.14

SyncSort for z/OS 1.2 Programmers Guide

Chapter 15. Value-Added Products

This chapter describes SyncSorts value-added products: Visual SyncSort for z/OS PROC SYNCSORT - An Accelerator for SAS Sorting PipeSort

These products significantly improve sorting efficiency and enhance programmer productivity.

Visual SyncSort
SyncSort for z/OS incorporates functionality to integrate Visual SyncSort with SyncSort for z/OS mainframe processing. Visual SyncSort is a separately available PC product that is designed to allow programmers and non-programmers alike to easily create and manage SyncSort applications for the mainframe environment. With Visual SyncSort, you can create new sort, merge, and copy applications, or you can import and modify existing ones. Visual SyncSort saves programmer time while taking full advantage of the processing power of SyncSort for z/OS. Visual SyncSort does not require knowledge of sort syntax, so training time for new programmers is reduced dramatically. Buttons, pull-down menus, and other aids make navigation easy, and comprehensive context-sensitive Help is always available. Instant error

Chapter 15. Value-Added Products

15.1

checking provides immediate feedback. Visual SyncSort generates applications that run correctly the first time, because they are always free of syntax errors. Visual SyncSorts data dictionary and interactive design work together in a visual environment that greatly simplifies application development. Once you identify a field in your record layout by its position, length, and format and define a name for it (or import a COBOL file definition with the same information), you simply specify fields by name in your application. Visual SyncSort tracks the position and length of all fields, automatically handling changes in field specifications that occur as a result of output reformatting, data conversion, summarization, arithmetic manipulation, and report writing. When you develop an application, Visual SyncSort leads you through a series of dialogs that make SyncSorts powerful features easily available. Based on your responses, Visual SyncSort builds the SyncSort for z/OS control data set for you, so you can concentrate on what you want to do, not how to do it. And Visual SyncSort checks the information you enter as you are building the application, eliminating the need for debugging runs. Visual SyncSort makes it easy to develop reports because you type features like headers and trailers on your computer screen exactly as you want them in your report. You can import existing mainframe applications into Visual SyncSort to enjoy the benefits of modifying them through the Visual SyncSort interface. Visual SyncSort will automatically generate field names and lay out the entire application so you can modify and re-use it quickly and easily. Visual SyncSort automatically analyzes input and output specifications, and creates an optimized application that runs fast and minimizes SyncSorts use of system resources. For every Visual SyncSort application, you get a clearly laid out, consistently formatted application description, rather than cryptic control statements.

PROC SYNCSORT - An Accelerator for SAS Sorting


PROC SYNCSORT - An Accelerator for SAS Sorting is a high performance replacement for the SAS-provided procedure PROC SORT. Compared to PROC SORT, PROC SYNCSORT reduces the resources required for sorting within SAS applications and significantly cuts sort elapsed time. Sort processing within SAS often consumes as much as 30 percent of CPU time and EXCPs. Because sorting is such a large part of system activity, PROC SYNCSORTs efficiency results in noticeable improvements in overall system throughput. This reduced elapsed time from PROC SYNCSORT makes it possible for SAS applications to complete much faster. PROC SYNCSORT improves performance by providing a direct interface between SyncSort and SAS. This frees SyncSort to use its high performance techniques - sophisticated access methods, path length minimization algorithms and I/O optimization. No modifications to SyncSort are required to install and use PROC SYNCSORT.

15.2

SyncSort for z/OS 1.2 Programmers Guide

For more detailed information regarding the use and installation of PROC SYNCSORT, refer to the booklet titled PROC SYNCSORT Installation and Use Guide.

PipeSort
PipeSort works with SyncSort to run multiple sorts simultaneously on the same input data. For large input files, PipeSort significantly reduces total elapsed time compared to running separate sort jobs. PipeSort reads SORTIN once and distributes the input records to up to eight simultaneous SyncSort executions. The complete range of SyncSort control statements and PARMs is available for the individual sort operations. The output files are differently sequenced according to user-specified sort keys and are written to different SRTnOUT DD data sets. Optionally, you can use an inline E15 exit, with or without one or more E35 exits. An inline E15 input exit can supply the input data to PipeSort, and E35 output exits can accept the different output record sets. For detailed information regarding installation and implementation through z/OS JCL, refer to the PipeSort Users Guide.

Chapter 15. Value-Added Products

15.3

15.4

SyncSort for z/OS 1.2 Programmers Guide

Chapter 16. Messages

All messages issued by SyncSort have the form: WERnnnx Message text where nnn is the message number and x may be any of the letters A through I. The interpretation of the suffix letter x is given below. A (action) message indicates a critical error condition: SyncSort terminates in order to allow the user to correct the error(s) so that a successful sort/merge may be run. Example WER002A EXCESS CARDS

B (tuning) messages provide information that may be useful in adjusting the job/control stream to the actual demands of the job. These messages only print if a critical error forces sort termination or if B messages were requested at execution or installation time. Example WER151B SECONDARY EXTENTS OBTAINED xxx

C-I (informational) messages document decisions internal to the sort as well as SyncSorts response to error conditions which are not severe enough to warrant sort/merge termination. Example WER177I TURNAROUND SORT PERFORMED WER185I SORTIN DCBBLK GT ACTUAL, I/O INEFF

Chapter 16. Messages

16.1

SyncSort for z/OS provides an interactive message explanation facility, SS12MSG, that gives online access to all SyncSort message texts and their explanations by message number. If SS12MSG is included as an option in a PDF menu, you may invoke from that menu. Otherwise, you may invoke SS12MSG from the command line of any ISPF panel by entering the following command:

TSO %SS12MSG

The installation of the SS12MSG facility is optional. Therefore, if you are unable to invoke the facility as described, you should contact your system administrator for more information. Note: All messages that refer to SORTIN, SORTWK, SORTOF, and SORTOUT provide the actual DD name, which reflects any changes made via a prefix override. WER001A COL 1 OR 1-15 NOT BLANK EXPLANATION: This message is triggered by a character in column 1 of the END control statement or in columns 1-15 of a continuation statement following a statement with a character in column 72, or by a non-blank character in columns 1-15 of a sort control statement in the $ORTPARM data set. These columns must be left blank. WER002A EXCESS CARDS EXPLANATION: The static internal storage area is inadequate for the quantity and/or complexity of the control statements in this application. Either the minimum storage value set at installation time is too low, or insufficient storage is available in your region. ACTION: Ask the systems programmer in charge of SyncSort installation to increase the minimum storage (MINCORE) value unless the storage available in the region is less than the minimum storage value. In that case, increase the storage available in the region or partition so that it at least equals the minimum storage value. WER003A NO CONTIN CARD EXPLANATION: A continuation statement was indicated by a nonblank character in column 72 of a control statement or by a control statement ending in an operand-comma combination; no continuation statement followed.

16.2

SyncSort for z/OS 1.2 Programmers Guide

WER004A

INVALID OP DELIMITER EXPLANATION: A control statement ends with an incorrect delimiter, such as a comma.

WER005A

STMT DEFINER ERR EXPLANATION: A control statement contains an invalid operation name. (Tape Sort accepts fewer operation names than Disk Sort, MAXSORT and PARASORT.)

WER006A

OP DEFINER ERR EXPLANATION: An operation name must be followed by an operand on the same control statement.

WER007A

SYNTAX ERROR - {S/M,REC,MOD} EXPLANATION: The control statement shown in the message contains a syntax error.

WER008A

FLD OR VALUE GT 8 CHAR - {S/M,REC,MOD} EXPLANATION: A parameter exceeds eight characters on the statement shown in the message.

WER009I

EXCESS INFO ON CARD - {S/M, REC,MOD} EXPLANATION: The control statement shown in the message contains more information than necessary. This excess information will be treated as a comment.

WER010A

NO S/M CARD EXPLANATION: The SORT/MERGE control statement is required for all SyncSort applications including a straight copy (coded SORT FIELDS=COPY or MERGE FIELDS=COPY).

WER011A

TOO MANY S/M KEYWORDS EXPLANATION: The maximum of eight keyword operands for tape sort was exceeded on a control statement.

WER012A

NO FLD DEFINER EXPLANATION: The FIELDS operand was not specified on the SORT/ MERGE control statement.

Chapter 16. Messages

16.3

WER013A

INVALID S/M KEYWORD EXPLANATION: An invalid keyword operand was found on the SORT/ MERGE control statement.

WER014A

DUPLICATE S/M KEYWORD EXPLANATION: A keyword operand was defined more than once on the SORT/MERGE control statement.

WER015A

TOO MANY PARAMETERS EXPLANATION: A keyword operand on the SORT/MERGE control statement contains too many parameters.

WER016A

INVALID VALUES IN FLD EXPLANATION: An invalid value was specified in the FIELDS operand on the SORT/MERGE control statement.

WER017A

ERR IN DISP LENGTH VALUE EXPLANATION: The length and displacement value of a control field is greater than 4092 (4084 for variable-length records), or less than one, or the sum of the lengths of all control fields exceeds 4092 (4084 for variable-length records).

WER018A

CTL FLD ERR EXPLANATION: An error was detected in the SORT/MERGE control statement for the data format of a control field. The format was specified for one field but not for another, or bit comparisons were specified and FORMAT=BI was not specified.

WER019A

SIZE/SKIPREC ERR EXPLANATION: The SIZE or SKIPREC parameter was incorrectly specified.

WER020A

INVALID REC KEYWORD EXPLANATION: An invalid keyword was detected in a RECORD control statement.

16.4

SyncSort for z/OS 1.2 Programmers Guide

WER021A

NO TYPE DEFINER EXPLANATION: The TYPE operand must be specified in the RECORD control statement.

WER022A

RCD FORMAT NOT F/V EXPLANATION: An invalid RECFM was detected for SORTIN or SORTOUT.

WER023A

NO LENGTH DEFINER EXPLANATION: The LENGTH operand must be specified on the RECORD control statement.

WER024A

ERR IN LENGTH VALUE EXPLANATION: An invalid LENGTH subparameter was found in a RECORD control statement. For example, l5 was greater than l1 or l4 was greater than l2.

WER025A

RCD SIZE GT MAX EXPLANATION: The LENGTH operand in a RECORD control statement specified a value which is greater than the maximum value allowed (32,767).

WER026A

L1 NOT GIVEN EXPLANATION: The LENGTH operand on a RECORD control statement does not contain an l1 value.

WER027A

CONTROL FIELD BEYOND RECORD EXPLANATION: The last byte of a SORT/MERGE or JOINKEYS control field is located beyond the maximum record length specified or column 32750, or a variable-length record is shorter than the ending location of a specified SORT/MERGE or JOINKEYS control field in an execution for which this is defined as cause for SyncSort termination (see VLTEST). Program HISTOGRM may be used to determine the length of the shortest record in the input file.

WER028A

TOO MANY EXITS EXPLANATION: More than the maximum number of exits allowed (16) were specified.

Chapter 16. Messages

16.5

WER029A

IMPROPER EXIT EXPLANATION: The set of legal exits depends on the sorting technique chosen. Tape Sort does not support E14 or E32; a merge or copy may not specify any Phase 1 or Phase 2 exits; a copy may not specify exit E32 or E61; and a sort or merge with data fields of Y2x or PD0 formats may not specify exit E61.

WER030A

MULTIPLY DEFINED EXIT EXPLANATION: The same program exit was specified twice on a MODS control statement.

WER031A

INVALID MODS OP CHAR EXPLANATION: An invalid character was detected in a parameter on a MODS control statement.

WER032A

EXIT E61 REQUIRED EXPLANATION: A SORT control statement specified "E" in the FIELDS parameter but program exit E61 was not specified on a MODS control statement.

WER033A

CONTROL FIELD COLLATING ORDER E REQUIRED EXPLANATION: Program exit E61 was specified on the MODS control statement but "E" was not specified in the FIELDS parameter of the SORT control statement.

WER034A

PARAM ERR FOR MODS EXPLANATION: An incorrect number of parameters was given for an operand on a MODS control statement, or SYSIN was specified on a MODS control statement as the source for user exit routines but a // SORTMODS or //SYSIN statement is missing or dummy.

WER035A

DUPLICATE MOD RTN IN PHASE EXPLANATION: The same exit routine was used for more than one program exit in the same phase of a tape sort, or two or more exit routines in a tape sort have the same name.

WER036B

G=ggg, B=bbb, SEGLEN=sss, BIAS=zz EXPLANATION: The tuning information displayed is as follows:

16.6

SyncSort for z/OS 1.2 Programmers Guide

G=ggg

ggg is the number of records that can be contained in SyncSorts working virtual storage area. For variablelength records, this number is the number of segments. bbb indicates the physical blocking used for intermediate storage. For fixed-length records, this number represents the blocking factor. For variable-length records, it represents the blocksize. The B value will not appear in the message for incore or turnaround sorts.

B=bbb

SEGLEN=sss This value appears in the message for variable-length records, when the execution is not an incore or turnaround sort. It reflects the segment length used in SyncSorts working storage during Phase 1. BIAS=zz zz reflects the degree of prior sequencing in the input data. The number displayed ranges from 00 to 99 indicating random to highly sequenced input. The BIAS value is not included in the message for an incore or turnaround sort, where it is 100 by definition.

WER037A

REXX ENVIRONMENT UNAVAILABLE EXPLANATION: One or more REXX exits were specified in a MODS control statement, but the required operating system and/or TSO environment is not available.

WER039A

INSUFFICIENT VIRTUAL STORAGE EXPLANATION: The amount of virtual storage available to SyncSort is not large enough to permit execution. Refer to the "Setting CORE" section of the Performance Considerations chapter for further information. ACTION: Verify that virtual storage is specified properly. Check that the region size is sufficient for execution.

WER040A

INSUFFICIENT WORK UNITS EXPLANATION: Tape Sort requires at least three work devices, numbered in order.

WER041A

N GT MAX EXPLANATION: The number of records specified in the SIZE parameter on a SORT control statement is greater than the NMAX value calculated by SyncSort.

Chapter 16. Messages

16.7

ACTION: Check SIZE parameter for error. If there is no error, increase intermediate storage. WER042A UNITS ASSGN ERROR EXPLANATION: The device type of a SORTWK data set is not valid. WER043A DATA SET ATTRIBUTES NOT SPECIFIED EXPLANATION: The DCB parameter was not specified for a SORTIN or SORTOUT data set. ACTION: Specify the DCB parameters. When including an E18 exit routine, this is necessary even when SORTIN is a standard labeled tape. WER044A EXIT Exx INVALID OPTION EXPLANATION: The exit routine shown in the message specified an invalid option for the modification of a DCB parameter of a sort/merge data set. WER045C END SORT PH EXPLANATION: SyncSort has completed its sort phase. WER046A SORT CAPACITY EXCEEDED EXPLANATION: All available intermediate storage is exhausted, including any secondary allocation allowed in this job set. Sort processing cannot continue. ACTION: Supply more intermediate storage (see the SORTWK calculation formula) or use the MAXSORT technique. WER047A RCD CNT OFF, IN x, OUT y EXPLANATION: The actual number of records specified in the SIZE parameter on the SORT control statement (the IN value) was not equal to the number of records read from the SORTIN data set (the OUT value). (This comparison is made only when the SIZE parameter specifies an actual number of records.) For Disk Sort, MAXSORT and PARASORT: the actual number of records (the IN value) for FILSZ=n specified either on the SORT control statement or as a PARM option was not equal to the total number of records (the OUT value) from the SORTIN data set after any changes

16.8

SyncSort for z/OS 1.2 Programmers Guide

due to the INCLUDE/OMIT control statement, and an E14 or E15 exit routine, and SKIPREC, STOPAFT, or join processing. For Tape Sort only: there is a discrepancy between the number of records entering and leaving a phase which is not accounted for by user exits (this is usually caused by an I/O error - try running the sort again). WER048I E16 EXIT CALLED EXPLANATION: Program exit E16 was entered after all available SORTWORK space was exhausted. WER049A SUM FIELD OVERFLOW EXPLANATION: Summarization of two equally keyed records could not be done due to a numeric overflow or underflow in a defined SUM field. The WER049A critical message is issued instead of the WER049I warning message if the OVFLO=RC16 PARM or the installation parameter SUMOVFL=RC16 is in effect. ACTION: If complete summarization is desired, use the INREC control statement if possible to pad the fields with leading zeros of the proper numeric format. Adjust the SUM field and other control statement fields accordingly. Visual SyncSort users may create an Advanced Field that could be substituted for the SUM field by using the Summation Field Expansion option. WER049I SUM FIELD OVERFLOW EXPLANATION: Summarization of two equally keyed records could not be done due to a numeric overflow or underflow in a defined SUM field. ACTION: If complete summarization is desired, use the INREC control statement if possible to pad the fields with leading zeros of the proper numeric format. Adjust the SUM field and other control statement fields accordingly. Visual SyncSort users may create an Advanced Field that could be substituted for the SUM field by using the Summation Field Expansion option.

Chapter 16. Messages

16.9

WER050I

SUM CONTROL STATEMENT IGNORED EXPLANATION: A SUM control statement was specified in a SORT FIELDS=COPY application. Since a COPY operation does not use SORT/MERGE key fields, the specification of SUM, which operates on equally keyed records, is illogical. ACTION: The SUM statement will be ignored, but the application should be checked for correct specification of control statements.

WER051A

UNENDING MERGE EXPLANATION: The intermediate storage provided is insufficient to complete the intermediate merge phase. ACTION: Assign more tape work units to the sort.

WER052I

END SYNCSORT - jobname, stepname, procstepname, DIAG=hhhh,hhhh,... EXPLANATION: SyncSort has successfully completed execution. The hexadecimal information following the DIAG keyword is likely to change from execution to execution. It is internal diagnostic information intended for use by SyncSort personnel in Product Support.

WER053A

OUT OF SEQ EXPLANATION: The current record leaving the final merge phase is not in collating sequence with the last record blocked for output.

WER054I

RCD IN x, OUT y EXPLANATION: For a non-join application, the x represents the number of records read from the input data set(s). For a join application, the x represents the resulting number of records created by the join processing. If OUTFIL statements are not present, the y represents the number of records in the output file. If OUTFIL statements are present, the y represents the number of records available for OUTFIL processing.

WER055I

INSERT x, DELETE y EXPLANATION: The x represents the number of records inserted by user exit routines. The y represents the number of records deleted by user exit routines, SUM, and INCLUDE/OMIT control statements.

16.10

SyncSort for z/OS 1.2 Programmers Guide

Note: For MAXSORT, these counts are cumulative for the entire MAXSORT application. WER056A SORTIN/SORTOUT NOT DEFINED EXPLANATION: A required SORTIN or SORTOUT DD statement could not be found. WER057A SORTIN NOT SORTWK01 EXPLANATION: A tape work data set other than SORTWK01 is assigned to the same tape unit assigned to SORTIN. WER058A SORTOUT A WORK UNIT EXPLANATION: A tape work data set is assigned to the same tape unit assigned to SORTOUT. WER059A RCD LNG INVALID FOR DEVICE EXPLANATION: The logical record length specified for a fixed-length input data set plus overhead, if any, is too large to fit on one disk track of the intermediate storage device, or (Tape Sort only) it is less than 18 bytes long. WER060A DSCB NOT DEFINED EXPLANATION: There are no DD names in the TIOT for any of the sort work data sets. WER061A I/O ERR jobname, stepname, unit address, device type, DDname, operation attempted, error description, last seek address or block count, access method. EXPLANATION: An I/O error has occurred on the device whose address is given. I/O errors are often transient - resubmitting the job may result in a successful run. However, if the I/O error is on an input DD, the following should be checked first: 1. When the input consists of concatenated data sets, check that the largest blocksize is available at sort initialization. See Concatenating Input Data Sets. 2. If the data set is on disk and has just been created by another program, check that this program opened the data set even if no data was written to the file. The data set must be opened in order for an end-of-file mark to be written. (In the absence of an end-of-file

Chapter 16. Messages

16.11

mark, SyncSort will tend to read whatever was on the disk as part of the input data set, causing an I/O error.) WER062A L E ERR EXPLANATION: The linkage editor detects an error so serious that execution cannot continue. WER063A xxxxxx OPEN ERR EXPLANATION: The data set shown cannot be successfully opened. ACTION: Check for missing DD statements. WER064A DELETE ERR EXPLANATION: A SyncSort program module is unable to delete itself or a user exit routine. WER065A DECK STRUCTURE ERROR EXPLANATION: The end of the SYSIN data set was reached before all user exit routines were read or an object deck was missing its first statement. WER066A APPROX RCD CNT x EXPLANATION: Sort capacity was exceeded, so the sort terminated. The approximate number of records processed by SyncSort up to this point is given. WER067I INVALID EXEC OR ATTACH PARAMETER EXPLANATION: An invalid parameter was detected in the PARM field of the EXEC statement or in the parameter list if SyncSort was initiated through ATTACH, LINK, or XCTL. Invalid parameters are ignored. (If a parameter is entered more than once, the last entry, if valid, is used.) WER068A OUT OF SEQ SORTINxx[, BLOCK y] EXPLANATION: A record in the SORTIN data set indicated by xx is out of sequence according to the FIELDS specification on the MERGE statement. The number y of the block containing the out-of-sequence record is given if an E32 exit was not used.

16.12

SyncSort for z/OS 1.2 Programmers Guide

WER069A

E39/OUTFIL INCOMPATIBLE EXPLANATION: The E39 exit facility may not be utilized in sorts/ merges which also specify OUTFIL control statements.

WER070A

ddname {TOTAL,SUBTOTAL,AVG,SUBAVG} FIELD OVERFLOW EXPLANATION: The ddname will be SORTOUT, SORTOFxx, SORTOFx or the ddname provided by an OUTFIL FNAMES parameter. An overflow condition was generated during the TOTAL, SUBTOTAL, AVG, or SUBAVG OUTFIL function for the specified output file. All fields are totaled internally as 8-byte PD values, allowing for 15 decimal digits. ACTION: This error is usually due to invalid data in the specified fields. Check the fields specified in the indicated parameter and check the actual data in those fields to ensure that no total will exceed 15 decimal digits. In some cases, within TRAILER2 or TRAILER3, you could change SUBTOTAL to TOTAL or SUBAVG to AVG to reduce the possibility of overflow.

WER071A

MAXIMUM NUMBER OF RECORDS EXCEEDED EXPLANATION: SyncSorts default internal limit on the maximum number of records that can be sorted has been exceeded. By default, the internal limit on the number of records that can be processed for variable-length data or for a sort application that uses the EQUALS option is 4,294,967,295 records. Specify the EXTCOUNT PARM to increase the internal limit to 140,737,488,355,327 records. Fixed-length sorts without EQUALS have automatic support for the maximum number of records allowed by the EXTCOUNT PARM. For additional information, see the EXTCOUNT option in the PARM Options chapter.

WER072I

{EQUALS, NOEQUALS} [,RESET] IN EFFECT EXPLANATION: This informational message indicates the status of two SyncSort options that could affect how your data was processed. The status of the EQUALS option, primarily used to retain the sequence of equally-keyed input records, is given first. RESET is indicated if the RESET option was used to prevent VSAM from treating output data sets created with the REUSE option as MOD data sets.

WER100A

DUPLICATE RECORD KEYWORD EXPLANATION: A keyword operand was defined twice on a RECORD control statement.

Chapter 16. Messages

16.13

WER101D

INVALID TAPE TYPE IN PARM FIELD EXPLANATION: An invalid tape type was specified for DEVIN/ DEVOUT in the PARM field of the EXEC statement. SyncSort ignored the invalid parameter.

WER102A

COBEXIT=COB2 AND COBOL E15 AND E35 EXITS FOUND IN COPY APPLICATION EXPLANATION: A COBOL E15 and COBOL E35 may not both be specified in a copy application if the COBEXIT=COB2 installation option is in effect. Only one of the exits is permitted.

WER103D

INVALID MESSAGE TYPE IN PARM FIELD EXPLANATION: An invalid message code was specified in the PARM field of the EXEC statement or in the invoking program parameter list. SyncSort ignored the invalid parameter.

WER104A

REXX E15 AND REXX E35 EXITS FOUND IN A COPY APPLICATION EXPLANATION: A REXX E15 and a REXX E35 may not both be specified in a copy application. Only one of the exits is permitted.

WER105A

INCOMPATIBLE LEVELS BETWEEN THE STATIC AND DYNAMIC LIBRARIES OF A COBOL OR C EXIT EXPLANATION: When using either a C or COBOL exit, insure that the run-time dynamic Language Environment libraries are at the same or higher level than the libraries used for the compile or link-edit of the exit.

WER106A

ddname INVALID DEVICE TYPE EXPLANATION: The ddname is either SORTIN, SORTINnn, SORTJNF1, SORTJNF2, SORTOUT, SORTOFxx, SORTOFx or the ddname provided by an OUTFIL FNAMES parameter. This file resides on an invalid device type. Valid device types include the IBM 3380, 3390, and 9345 direct access devices and their equivalents as well as the IBM 3420, 3480, 3490, and 3590 series tape devices and their equivalents.

WER107A

ddname RECFM INCOMPATIBLE WITH REPORT WRITING EXPLANATION: The ddname will be SORTOUT, SORTOFxx, SORTOFx or the ddname provided by an OUTFIL FNAMES parameter.

16.14

SyncSort for z/OS 1.2 Programmers Guide

The RECFM specified for the file did not include the 'A' (ASA control character) specification that is required when report writing is requested. WER108I ddname: RECFM= ;LRECL= {;BLKSIZE=,CISIZE=} [;CINV ACCESS] EXPLANATION: The ddname will be SORTIN, SORTJNF1, or SORTJNF2. This informational message lists the DCB characteristics used by SyncSort to process the input file. For a non-VSAM data set that is concatenated, the DCB characteristics are for the first of the concatenated data sets, except for BLKSIZE, which is the largest of all data sets in the concatenation examined at sort initialization time. For a VSAM data set, the CISIZE is provided; if control interval access was used, the CINV ACCESS portion of the message will be displayed. WER109I MERGE INPUT: TYPE={F,V};LRECL= EXPLANATION: This informational message lists the DCB characteristics used by SyncSort to process the input files for a merge. WER110I ddname RECFM= ;LRECL= {;BLKSIZE=,CISIZE=} [;CINV ACCESS] EXPLANATION: The ddname will be SORTOUT, SORTOFxx, SORTOFx or the ddname provided by an OUTFIL FNAMES parameter. This informational message lists the DCB characteristics used by SyncSort to process the indicated output file. This message will be provided for each output file specified. For a VSAM data set, the CISIZE is provided; if control interval access was used, the CINV ACCESS portion of the message will be displayed. WER111A [ddname] {INREC,OUTREC,TOTAL/SUBTOTAL,MIN/SUBMIN, MAX/SUBMAX,AVG/SUBAVG} INVALID DATA CONVERSION REQUESTED EXPLANATION: The ddname will be SORTOUT, SORTOFxx, SORTOFx or the ddname provided by an OUTFIL FNAMES parameter. Data conversion has been requested for INREC, OUTREC, OUTFIL OUTREC, TOTAL/SUBTOTAL, etc., as indicated, and one of the following error conditions has occurred: 1. The length of the field to be converted is too large. 2. Data conversion has been requested for a field that is not specified as BI, CSF/FS, FI, PD, Y2ID, Y2IP or ZD.

Chapter 16. Messages

16.15

3. Illegal or conflicting EDIT/SIGNS parameters were specified. WER112A INVALID VALUES IN FIELD PARAMETER EXPLANATION: An invalid value was specified in the FIELDS operand of the SORT/MERGE control statement. WER113A TOO MANY SORT FIELDS EXPLANATION: The number of sort control fields specified exceeds the internal limits of the product. The absolute upper limit on the number of sort control fields is 128; however, depending on the complexity of an application, the limit may be reduced. When locale processing is used, the number of allowable CH control fields is also limited by the length of those fields. WER115A ILLEGAL MOD NAME EXPLANATION: An invalid name for a program exit was entered on a MODS control statement. WER116A THE FOLLOWING H/T IS GT LRECL: EXPLANATION: This message flags any HEADERs or TRAILERs that exceed the LRECL specification. The HEADER or TRAILER in error will be printed on the next line. WER117A INVALID ANSI CONTROL CHARACTER FOUND EXPLANATION: An invalid ANSI control character appears in a HEADER or TRAILER. The ANSI Control Character Table lists the valid characters accepted by SyncSort. WER117I INVALID ANSI CONTROL CHARACTER FOUND EXPLANATION: An invalid ANSI control character appears in an output data record. The sort will process the record as if a blank control character had been found. This message will be issued only once regardless of how many data records have invalid ANSI characters. The ANSI Control Character Table lists the valid characters accepted by SyncSort. WER118A ddname ILLEGAL OVERLAPPING FIELDS EXPLANATION: The ddname will be SORTOUT, SORTOFxx, SORTOFx or the ddname provided by an OUTFIL FNAMES parameter. An OUTFIL control statement contains a HEADER or TRAILER

16.16

SyncSort for z/OS 1.2 Programmers Guide

parameter which contains overlapping fields. This may be caused, for example, by a positional sub-parameter specification which overlaps a previously defined field. WER119A NO DD NAME IN MODS FIELD EXPLANATION: A DD name is missing on the MODS control statement. WER120A SEP. LKED NOT ALLOWED EXPLANATION: A module for which separate link-editing was specified on a MODS control statement is not allowed to be link-edited separately. WER121A TASK CALL PARAM ERROR EXPLANATION: If a 24-bit list is being used, either a control statement address is zero, or the length of a control statement is not positive, or the parameter list ends with the first word of a two-word parameter. If a 31-bit list is being used, the last parameter word in the list is not followed by the four byte field X'FFFFFFFF'. WER122A INVALID INTERMEDIATE STORAGE DEVICE EXPLANATION: An invalid device was assigned as intermediate storage. Valid devices include IBMs 3380, 3390, and 9345 mass storage system, and equivalent units. A tape device may not be used unless Tape Sort is installed. WER123A IMPROPER RETURN CODE FROM Exx EXPLANATION: An invalid return code was passed by the exit that appears in the message. Valid return codes are 0, 4, 8, 12, 16 (and 20, if the exit is a COBOL or C E15 or E35). WER124I [ESTIMATED] PREALLOCATED/USED SORTWORK SPACE USAGE FACTOR {=,<,>}nn.nn EXPLANATION: nn.nn represents the quotient obtained by dividing the number of tracks assigned within preallocated sortworks (sortworks allocated in the JCL or dynamically allocated by an invoking program) by the number of tracks actually used by SyncSort. The word ESTIMATED is included in when SyncSorts derivation of this factor is inexact, for example, when all sortwork data sets are not opened, or when data space or hiperspace are used to contain part or all of the sortwork data.

Chapter 16. Messages

16.17

Note that for MAXSORTs, the factor displayed is at or near "1.00" for all but the last sort. For the last sort, the factor may be anywhere between "0.01" and "1.00" depending on the amount of data sorted. WER125A NO DATA ON MODS CARD EXPLANATION: The MODS control statement contains no parameters. WER128A INVALID CARD BEFORE END CARD EXPLANATION: A control statement containing an error was found. WER130A I/O ERROR ON SYSIN EXPLANATION: An I/O error occurred on SYSIN. WER131I PARM FIELD ERROR - xxxxxxxx EXPLANATION: An invalid PARM was found in the PARM field string that was passed to SyncSort. SyncSort terminated the PARM processing by ignoring the remainder of this PARM string without terminating the SyncSort application. The invalid PARM is displayed in the message text if the PARM was passed on the EXEC statement. If the invalid PARM was passed through the $ORTPARM DD statement, the entire PARM string is written to the SYSOUT data set, and an asterisk is displayed beneath the invalid PARM. WER133A Exx USER EXIT RETURNED CODE TERMINATE EXPLANATION: Return code 16 was passed by the exit routine shown in the message. SyncSort terminated. WER135A TASK CALL/E35 TERMINATED PREMATURELY EXPLANATION: An E35 exit routine (COBOL Output Procedure) passed a return code of 8, terminating the sort before the sort was able to pass all of the records. A SORTOUT data set was not present. WER135I TASK CALL/E35 TERMINATED PREMATURELY EXPLANATION: An E35 exit routine (COBOL Output Procedure) passed a return code of 8, terminating the sort before the sort was able to pass all of the records. A SORTOUT data set was not present. This message may not indicate an error condition - it depends on what the programmer intended. For example, this message will be generated

16.18

SyncSort for z/OS 1.2 Programmers Guide

if a COBOL program using the SORT verb RELEASEs 100 records in the Input Procedure without RETURNing all 100 records in the Output Procedure because the logic dropped to the bottom of the Output Procedure prematurely. If this is what the programmer intended, then no data has been lost. If, however, the programmer intended the Output Procedure to write all the records read in the Input Procedure, then this message indicates a logic bug in the COBOL program. WER136A {INREC,OUTREC,ddname OUTREC} HAS OVERLAPPING FIELDS SPECIFIED EXPLANATION: The column specification of a c: sub-parameter in the indicated control statement overlaps a field previously defined in the same control statement. Note that the sub-parameters used to define each field must be coded in the order in which the fields will appear in the reformatted record. The ddname will be SORTOUT, SORTOFxx, SORTOFx or the ddname provided by an OUTFIL FNAMES parameter. WER138A ddname BLKSIZE NOT EVENLY DIVISIBLE BY LRECL EXPLANATION: The ddname is either SORTIN, SORTINnn, SORTJNF1, SORTJNF2, SORTOUT, SORTOFxx, SORTOFx or the ddname provided by an OUTFIL FNAMES parameter. A block was read from the indicated file whose length was not a multiple of the LRECL value, or the JCL or data set attributes are incorrect. WER141A ddname RECFM IS U EXPLANATION: The ddname is either SORTIN, SORTINnn, SORTJNF1, SORTJNF2, SORTOUT, SORTOFxx, SORTOFx or the ddname provided by an OUTFIL FNAMES parameter. SyncSort does not support undefined record format for any of these files. WER142A MIXED SORTIN TYPES F/V NOT SUPPORTED EXPLANATION: SyncSort permits only one record format type (fixed or variable) for input files per sort/merge. WER143A SORTIN LRECLS ARE MIXED EXPLANATION: The LRECL must be the same for all fixed-length files supplied to a merge. WER144B UNEXPECTED VIRTUAL STORAGE FRAGMENTATION EXPLANATION: The amount of virtual storage calculated by SyncSort for Phases 2 or 3 was not available in a contiguous block. Additional vir-

Chapter 16. Messages

16.19

tual storage was obtained to satisfy the sort requirement. This condition was probably caused by virtual storage not released by the user program in the job step (for example, user exit buffer space was not released). WER146B nnn BYTES OF EMERGENCY SPACE EXPLANATION: The indicated amount of virtual storage has been set aside by SyncSort for use by other programs (e.g., program invoking the sort, system SVCs, tape management system). WER147I CONTROL FIELD GT REC LEN, POSSIBLE OUT OF SEQ REC EXPLANATION: The sort encountered a variable-length record that was too short to contain all of the control field(s) specified in the SORT statement. VLTEST instructed SyncSort to pad the record with binary zeros to the length of the sort key and continue processing. The added binary zeros account for the position of this record in the sorted file, which may appear to be out of sequence for this reason. The binary zeros are removed when the record is processed for output. Program HISTOGRM may be used to determine the length of the shortest record in the input file. WER148A OPEN ERR SYSIN EXPLANATION: SYSIN is either not present or cannot be opened. WER149B FRAGMENTED VIRTUAL STORAGE IN SORT PHASE EXPLANATION: The virtual storage specified for SyncSorts use was not available in a contiguous block for Phase 1. This condition was probably caused by a calling program or user exit routine. SyncSort obtained its virtual storage in fragments and continued execution. Note that the calling program or user exit routine used virtual storage in such a way as to cause fragmentation, which might another time result in ABEND 80A or S804. WER151B SECONDARY EXTENTS OBTAINED xxx EXPLANATION: This gives the number of secondary extents obtained for SORTWKxx data sets.

16.20

SyncSort for z/OS 1.2 Programmers Guide

WER152B

REQUESTED VIRTUAL STORAGE NOT AVAILABLE, nnn BYTES USED EXPLANATION: The CORE parameter specified a value which was not available when SyncSort received control. The number of available bytes used by SyncSort is given.

WER153A

INSUFFICIENT VIRTUAL STORAGE IN {INT.,FINAL} MERGE PHASE EXPLANATION: The amount of virtual storage available for the indicated merge phase (the intermediate or final merge phase) was not sufficient to allow execution. Refer to the "Setting CORE" section of the Performance Considerations chapter for further information.

WER154A

NO MODS DD CARD EXPLANATION: The DD statement whose name was specified on the MODS control statement was not provided, so the user exit routine cannot be found.

WER157A

SPANNED REC. LEN LARGER THAN LRECL/L2 EXPLANATION: A record from a VBS input data set contains a record longer than the maximum record length specified by LRECL in the DCB. ACTION: Execute program HISTOGRM to get the length of the longest record in the data set. Use this length for the LRECL value in the DCB parameter of the input data set.

WER158I

REC. LEN GT L2, CUT TO L2 EXPLANATION: A variable-length record read from the SORTIN data set is longer than the maximum record length specified by either LRECL in the DCB or the l2 value in the RECORD control statement. (If l2 was not specified, the variable-length record is longer than the l1 value.) SyncSort has truncated the record. ACTION: If truncation is not desired, execute program HISTOGRM to get the length of the longest record in the data set. Use this length for the LRECL value in the DCB parameter of the SORTIN data set.

WER159A

REC LEN 0, {SORTIN REC x, INSERTED REC x} EXPLANATION: An invalid variable-length record (length code <4 in its Record Descriptor Word) has been found. If the record was found in

Chapter 16. Messages

16.21

the input file, the number of the invalid record is given. If the record was inserted from a user exit routine, the number of the inserted record is given (for example, 45 indicates the forty-fifth record read from the input file or inserted by a user exit.) WER160A REC. LEN GT LRECL/L2, USER REQ ABORT EXPLANATION: VLTEST has requested the sort to abort because of the following condition. A variable-length record read from the input file is longer than the maximum record length specified by LRECL in the DCB or (after E15 processing) is longer than the l2 value in the RECORD control statement. (If l2 was not specified, the l1 value was used as its default.) ACTION: Change the LRECL or l2 value to reflect the record length, or specify another value for VLTEST. Program HISTOGRM may be used to determine the length of the longest record in the input file. WER161B ALTERNATE PARM USED EXPLANATION: The alternate PARM option ($ORTPARM DD, PARMEXIT or PARMTABLE) was used and SyncSort received the parameters specified. WER162B ppp PREALLOCATED SORTWORK TRACKS, ddd DYNAMICALLY ALLOCATED sss ACQUIRED IN xxx SECONDARY EXTENTS, rrr RELEASED, TOTAL OF uuu TRACKS USED EXPLANATION: ppp is the number of tracks found available in sortwork data sets which were allocated prior to SyncSorts gaining control. (These may have been allocated in the JCL or dynamically allocated by an invoking program.) ddd is the number of tracks dynamically allocated as primary space by SyncSort. sss is the number of tracks acquired as secondary space, on both preallocated data sets and data sets dynamically allocated by SyncSort. xxx is the total number of secondary extents acquired. rrr is the total number of unneeded tracks released from both preallocated data sets and data sets dynamically allocated by SyncSort. uuu is the total number of tracks actually used in sorting. The following notes apply to the information in this message: ppp may not represent all of the preallocated tracks available, since not all preallocated sortwork data sets may be opened by SyncSort. uuu may be less than the sum of ppp, ddd and sss since it represents the space actually used and not the space available.

16.22

SyncSort for z/OS 1.2 Programmers Guide

For MAXSORTs, all dynamic allocation and secondary space acquisition is done during the first sort. For this reason, the WER162B message for the first sort will indicate the number of tracks dynamically allocated, the number acquired via secondary extents, etc. However, the WER162B message in all subsequent MAXSORT sorts will report these tracks as preallocated.

WER164B

www BYTES OF VIRTUAL STORAGE AVAILABLE, xxx BYTES REQUESTED, yyy BYTES RESERVE REQUESTED, zzz BYTES USED EXPLANATION: The amount of virtual storage available (free) when SyncSort received control is represented by ws. The amount of virtual storage requested for SyncSorts use is represented by xs. The amount of virtual storage that the user requested SyncSort to reserve below the 16-megabyte line is represented by ys. The amount of virtual storage used by SyncSort is represented by zs. This message reflects the total amount of virtual storage below and above the 16-megabyte line that was available to SyncSort and used by SyncSort.

WER165I

STAT DATA REC NOT WRITTEN EXPLANATION: The installation default for the SyncSort SMF record feature is applied, but the sort did not invoke the module that creates the sort statistical record. A possible reason for the sorts not invoking the module may be that FREE=CLOSE was coded on the SORTOUT (SYSUT2) or SORTWKxx DD statement. ACTION: Remove the FREE=CLOSE parameter if full SMF statistics are desired.

WER166I

REC LEN GT L3, CUT TO L3 EXPLANATION: SyncSort has truncated a variable-length record prior to output processing. If an E35 exit was in use, the truncated record was longer than the LRECL of the output files DCB or greater than the l3 value on the RECORD control statement. If an E35 exit was not in use, the truncated record was longer than the LRECL in the output files DCB. If OUTFIL processing is requested additional truncation may occur as a result of the OUTFIL processing regardless of the action requested by the VLTEST PARM.

WER167A

REC LEN GT L3, USER REQ ABORT EXPLANATION: Prior to output processing SyncSort has encountered a variable-length record longer than the l3 value on the RECORD control statement (if an E35 exit was in use) or longer than the LRECL in

Chapter 16. Messages

16.23

the output files DCB. The VLTEST PARM requested SyncSort to terminate when this condition occurs. ACTION: Change the LRECL in the output files DCB or the l3 value on the RECORD control statement (if an E35 exit is used) to reflect the correct record length, or specify another value for the VLTEST PARM. WER168A CONTROL FIELD WITHIN RDW EXPLANATION: A SORT/MERGE control field for a variable-length file fell within the Record Descriptor Word of each record. This is a critical error whenever the control field is specified with a ZD or PD format code. WER168I CONTROL FIELD WITHIN RDW EXPLANATION: A SORT/MERGE control field for a variable-length file falls within the Record Descriptor Word of each record. (The first byte of the data portion of a variable-length record is at byte position 5.) WER169I RELEASE r.r BATCH nnnn TPF LEVEL n.n EXPLANATION: Details on the release level, the batch number from the base installation tape, and the last TPF applied to SyncSort are given. WER170A CONCAT DS, BLKSIZE NOT DIVIS BY LRECL EXPLANATION: One of the files concatenated to a fixed-length input data set has a BLKSIZE that is not evenly divisible by the original LRECL. ACTION: Check the BLKSIZE specified on each of the DD statements concatenated to the first DD statement of the input. WER171A CONCAT DS, LRECLS NE OR RECFMS DIFF EXPLANATION: One of the files concatenated to a fixed-length input data set has an LRECL not equal to the original LRECL; or one of the files concatenated to a variable-length data set has an LRECL greater than the original LRECL; or one of the files concatenated to a fixed or variable-length data set has a RECFM not equal to the original RECFM.

16.24

SyncSort for z/OS 1.2 Programmers Guide

WER172A

CONCAT DS, BLKSIZE GT ORIG BLKSIZE EXPLANATION: One of the files concatenated to an input data set has a BLKSIZE greater than the original BLKSIZE.

WER173A

BDW INVALID EXPLANATION: The Block Descriptor Word of a block in the input data set contains a value less than 8; or the Block Descriptor Word contains a value greater than the number of bytes actually read. ACTION: Check the data set for the invalid block.

WER174A

RDW INVALID, OVERFLOWS BUFFER EXPLANATION: The Record Descriptor Word of a record in the input data set is too large. (According to the RDW, the record extends beyond the buffer.) ACTION: Execute HISTOGRM to check the data set for an invalid record.

WER175A

INCORE SORT CAPACITY EXCEEDED EXPLANATION: There are too many input records to fit in virtual storage. ACTION: Either increase the amount of virtual storage the sort is able to use or supply SORTWKxx DD statements. (The DYNALLOC option may be used instead of SORTWKxx DD statements.)

WER176A

USER EXIT LKED FAILED EXPLANATION: Exit routine(s) needing to be link-edited were present, but the linkage editor passed a return code greater than 0. ACTION: Check that the DD statement specified on the MODS control statement is present in the JCL and contains the modules specified on the MODS statement. Check that all exits (except E11, E21, and E31) to be link-edited together have an external name identical to the exit name. Examine the linkage editor output for other errors.

WER177I

TURNAROUND SORT PERFORMED EXPLANATION: SyncSort was able to sort the input file without using intermediate storage (SORTWKxxs). All input data was contained in virtual storage.

Chapter 16. Messages

16.25

WER178A

ddname [nnnnn] MEMBER NOT FOUND EXPLANATION: An input DD statement specified a member of a partitioned data set that could not be found. If a value nnnnn is provided, it represents the concatenation number of the data set that has the member-not-found condition. ACTION: Check the DD statement for an error or list the members of the partitioned data set.

WER179A

ddname INVALID DCB PARAMETERS EXPLANATION: The ddname is either SORTIN, SORTINnn, SORTJNF1, SORTJNF2, SORTOUT, SORTOFxx, SORTOFx, or the ddname provided by an OUTFIL FNAMES parameter. SyncSort is unable to derive RECFM, LRECL, and BLKSIZE parameters from the JCL, the DSCB on the disk or the tape label. ACTION: Check the JCL and the disk or tape labels for the error.

WER180A

ddname MEMBER NOT SPECIFIED EXPLANATION: The indicated input or output DD statement defines a partitioned data set, but a member name has not been specified. ACTION: Specify a member name on the indicated DD statement or change the partitioned data set to a sequential data set.

WER182A

INVALID RDW ddname BLOCK x EXPLANATION: An invalid spanned record indicator was detected in an input file whose RECFM=VBS, or an invalid record length was detected in a copy operation. The block number of the file is given. ACTION: Execute HISTOGRM to check the data set for a record containing invalid span bits. You can also use the VLTEST option to turn off segment sequence checking if so desired.

WER183A

SORTWORK DATASET REQUIRED EXPLANATION: SORTWKxx data set(s) are required for one of the following conditions in this execution of SyncSort: (1) INCORE=OFF is specified as a PARM, (2) exit E14 or E16 is activated, (3) the SUM control statement is used, (4) the OUTREC control statement is used, (5) the checkpoint-restart facility is used, (6) SORTOUT is a VSAM data set, (7) the OUTFIL control statement is used. (All conditions only apply to sort applications.)

16.26

SyncSort for z/OS 1.2 Programmers Guide

WER184A

INVALID RETURN CODE FROM E32 EXPLANATION: The return code from merge exit E32 must be 8, 12, or 16.

WER185I

SORTIN DCBBLK GT ACTUAL, I/O INEFF EXPLANATION: The I/O rate is reduced to an inefficient level because the blocksize specified for the SORTIN data set is larger than the actual blocksize, causing excessive error correction. ACTION: Correct the blocksize specification for future jobs.

WER186I

SVC nnn IS INCORRECT VERSION OR NON-SYNCSORT - SVC NOT USED - INEFFICIENT SORT EXPLANATION: The SVC did not return a code indicating it was at the correct version level, therefore it was not used. The SVC is either at the wrong SyncSort release/maintenance level or is not a SyncSort SVC. The problem could cause less efficient I/O and/or loss of SMF records. ACTION: Notify your system programmer, who should check that the SVC has been installed in the system libraries, has been IPLed into the system, was specified via SYNCMAC, and was not incorrectly overridden via $ORTPARM or the PARM field.

WER187A

ddname CINV SIZE LT RECORD LENGTH BUT SPANNING NOT SPECIFIED EXPLANATION: The ddname will be SORTOUT, SORTOFxx, SORTOFx or the ddname provided by an OUTFIL FNAMES parameter. The record length is greater than the control interval size specified in the definition of the indicated VSAM data set, but the data set definition did not also include a specification for spanned records.

WER188A

ddname IS D.A./DSCB NOT FOUND/OBTAIN FAILED EXPLANATION: The ddname is either SORTIN or SORTINnn. SyncSort was unable to successfully issue an OBTAIN for the specified direct access data set and was therefore unable to determine the DCB characteristics for the file. The OBTAIN failed either because the volume parameter was incorrectly specified for the output file indicated or because the data set was deleted from the volume. (NOTE: the data set may still be in the master catalog even though the data set is no longer on the volume.)

Chapter 16. Messages

16.27

WER189A

ddname DCB RECFM REQUIRED EXPLANATION: The RECFM was not specified on the indicated input DD statement, nor was it available in the DSCB on disk nor the tape label, and the TYPE operand was not specified on the RECORD control statement.

WER190A

ddname DUPLICATE OUTFIL SPECIFICATION EXPLANATION: The ddname will be SORTOUT, SORTOFxx, SORTOFx or the ddname provided by an OUTFIL FNAMES parameter. The indicated output file is referred to more than once in FILES parameters on the OUTFIL control statement.

WER191A

ddname BLKSIZE/LRECL INVALID EXPLANATION: This message is displayed in conjunction with either WER108I or WER109I which will indicate the invalid DCB characteristic specification of the input ddname. BLKSIZE and LRECL must be equal if RECFM=F. BLKSIZE must be evenly divisible by LRECL if RECFM=FB. BLKSIZE must be greater than or equal to LRECL + 4 if RECFM=V.

WER192A

ddname DCB LRECL MISSING EXPLANATION: The LRECL was not specified on the indicated input DD statement, in the DSCB on the disk, in the tape label, or on the RECORD control statement.

WER193A

ddname DCB LRECL AND BLKSIZE MISSING EXPLANATION: The BLKSIZE or LRECL must be specified either on the indicated input DD statement, in the DSCB on the disk, or in the tape label. Alternatively, an l1 specification may be included on the RECORD control statement. None of these specifications were made.

WER194A

SORTOUT DCB REQRD/TAPE NOT SL EXPLANATION: DISP=OLD was specified on the SORTOUT DD statement, the tape label was not specified as SL in the LABEL parameter, and required DCB information (LRECL, RECFM, BLKSIZE) was not specified.

WER195A

ddname DCB REQUIRED/VSAM SORTIN EXPLANATION: The ddname will be SORTOUT, SORTOFxx, SORTOFx or the ddname provided by an OUTFIL FNAMES parameter.

16.28

SyncSort for z/OS 1.2 Programmers Guide

The indicated output file requires additional DCB information (RECFM, LRECL or BLKSIZE) on its DD statement. WER196A ddname RECFM=VB, LRECL GT BLKSIZE EXPLANATION: RECFM=VB requires the BLKSIZE of the input ddname to be greater than or equal to LRECL + 4. WER197A ddname RECFM=F/FB, LRECL/BLKSIZE INVALID EXPLANATION: The ddname will be SORTOUT, SORTOFxx, SORTOFx or the ddname provided by an OUTFIL FNAMES parameter. BLKSIZE and LRECL were not equal on the indicated DD statement for RECFM=F, or BLKSIZE was not a multiple of LRECL for RECFM=FB. WER198A ddname VARIABLE LRECL LE 4 EXPLANATION: The LRECL specification on the indicated input or output DD statement did not allow 4 bytes for the RDW plus 1 byte for data. WER199A ddname RECORD TYPE=V, BLKSIZE LE 8 EXPLANATION: The BLKSIZE specified for the indicated input or output DD statement did not allow 4 bytes for the BDW, 4 bytes for the RDW plus 1 byte of data. WER200A ddname RECFM=V/VB LRECL/BLKSIZE INVALID EXPLANATION: The ddname will be SORTOUT, SORTOFxx, SORTOFx or the ddname provided by an OUTFIL FNAMES parameter. RECFM=V or VB requires the BLKSIZE to be greater than or equal to LRECL + 4. WER201A ddname is D.A./DSCB NOT FOUND/OBTAIN FAILED EXPLANATION: The ddname will be SORTOUT, SORTOFxx, SORTOFx or the ddname provided by an OUTFIL FNAMES parameter. SyncSort was unable to successfully issue an OBTAIN for the specified direct access data set, and was therefore unable to determine the DCB characteristics of the indicated file. The OBTAIN failed either because the volume parameter was incorrectly specified for the indicated output file, or because the data set was deleted from the volume. (NOTE: the data set name may still be in the master catalog even though the data set is no longer on the volume.)

Chapter 16. Messages

16.29

WER202A

ddname RECFM INCOMPATIBLE EXPLANATION: The ddname will be SORTOUT, SORTOFxx, SORTOFx or the ddname provided by an OUTFIL FNAMES parameter. The record format of the output file is not the same as the input file, the record format of a record provided by an E15, or the record format created by a JOIN REFORMAT statement. (Both formats must be either fixed-length or variable-length.) If you want to convert a variablelength input file into a fixed-length output file, use the CONVERT parameter of the OUTFIL or OUTREC control statements. If you want to convert a fixed-length input file into a variable-length output file, use the FTOV parameter of the OUTFIL control statement.

WER206A

INVALID PAGEFIX SVC NUMBER EXPLANATION: SyncSorts EXCPVR facility is in use but no page-fix SVC number was specified at installation time. ACTION: Inform your systems programmer of this error condition.

WER207I

SORTCKPT DD STATEMENT MISSING OR INVALID EXPLANATION: SyncSort could not take checkpoints because a SORTCKPT DD statement was not supplied or the statement specified an invalid device for a checkpoint data set. Invalid devices include DUMMY data sets or devices other than disk or tape. Processing continued but checkpoints were not taken.

WER208I

MIXTURE OF SORTWK DEVICES EXPLANATION: SORTWKxx data sets were assigned to different device types.

WER209B

xxx PRIMARY AND yyy SECONDARY SORTOUT TRACKS ALLOCATED, zzz USED EXPLANATION: It was necessary for SyncSort to request one or more secondary allocations for SORTOUT. xxx is the number of tracks that were initially allocated, yyy is the total number of tracks acquired via secondary allocation, and zzz is the total number of tracks actually required to contain the SORTOUT data set.

WER210I

E15 RC INVALID, IGNORED EXPLANATION: A return code of 0 or 4 was passed by an E15 exit routine at a time when these return codes are invalid because SyncSort

16.30

SyncSort for z/OS 1.2 Programmers Guide

has not passed the E15 a record address. The invalid return code was ignored by SyncSort, and a return code of 8 was presumed. WER211B/I [ ] CALLED BY SYNCSORT; RC=xxxx EXPLANATION: The sort statistics routine (the name inserted in the message) is called by SyncSort. RC gives the code returned to SyncSort by the statistics routine. If RC does not equal zero, see "What to Do Before Calling z/OS Product Services" in this chapter. WER213A ILLEGAL SUM DATA FIELD EXPLANATION: A field with an illegal data length was specified on the SUM statement. ACTION: Correct the field length. WER215A [SORTOFnn] {INREC,OUTREC} ARITHMETIC OVERFLOW EXPLANATION: When using either INREC, OUTREC or OUTFIL OUTREC, an arithmetic calculation or a data format conversion had an overflow. An arithmetic calculation overflow will occur if any intermediate result exceeds 15 decimal digits or if division by zero is attempted. Overflow may also occur when converting a number with a value of 4G or more to BI format or a number with an absolute value of 2G or more to FI format. ACTION: Review the arithmetic calculations specified in the indicated statement for errors. If they appear to be correct, consider whether the data could possibly cause an overflow or division by zero. If possible, eliminate any data with questionable values via INCLUDE/OMIT. Consider changing the order of the calculations to prevent intermediate calculation overflow. WER216A SUM FIELD OUTSIDE RANGE EXPLANATION: A sum field on the SUM control statement is located beyond the record length. WER217A DYNALLOC {UNIT,STORCLASS} ASSIGNMENT ERROR EXPLANATION: Either the unit name or storage class name (DFSMS STORCLAS) is missing or specified incorrectly.

Chapter 16. Messages

16.31

WER218A

DYNALLOC WORKFILE ASSIGNMENT ERROR EXPLANATION: More than 32 work files were requested for dynamic allocation.

WER219A

DYNALLOC FAILED RC=(nnnn) - uuuuuuuu [-SMS RC=ssss] EXPLANATION: The execution of the DYNALLOC macro instruction failed. nnnn represents the error reason code, uuuuuuuu represents either the unit name or storage class name, and ssss represents the SMS return code (only present for certain failures detected by SMS). Two possible reason codes are: 021C - Undefined unit name. 0214 - Unit not available. If all specified units are unavailable when DYNALLOC is issued, the DYNALLOC request fails. For other reason codes, see either IBM publication z/OS MVS Programming: Authorized Assembler Services Guide SA22-7608 or OS/390 V2R10.0 MVS Authorized Assembler Service Guide GC28-1763.

WER219I

DYNALLOC FAILED RC=(nnnn) - uuuuuuuu [-SMS RC=ssss] SORT PROCESSING CONTINUES EXPLANATION: Dynamic allocation was unsuccessful. nnnn represents the error reason code, uuuuuuuu represents either the unit name or storage class name, and ssss represents the SMS return code (only present for certain failures detected by SMS). Sort processing continues with previously allocated SORTWKs and JCL-allocated SORTWKs. For an explanation of the error reason code, see either IBM publication z/OS MVS Programming: Authorized Assembler Services Guide SA227608 or OS/390 V2R10.0 MVS Authorized Assembler Service Guide GC28-1763.

WER220A

ILLEGAL OVERLAPPING OF SUM FIELDS EXPLANATION: A SUM field overlaps another SUM field, a SORT/ MERGE control field or the Record Descriptor Word of a variable-length record. All of these are illegal.

WER223A

ddname ASCII XLATION, BUT VOLUME IS NOT ASCII TAPE OR RECFM IS V EXPLANATION: RECFM=D was specified for the indicated input or output file which is not a tape data set. (RECFM=D is valid for tape

16.32

SyncSort for z/OS 1.2 Programmers Guide

data sets only.) Or, RECFM=D was specified for the input data set and no DCB was specified for the output data set. ACTION: In the first case, code correct RECFM for the data set specified; in the latter case, code DCB characteristics for the output data set, and rerun the job. WER224A ddname NOT DEFINED EXPLANATION: A required DD statement could not be found. WER225I E35 RC INVALID, IGNORED EXPLANATION: An invalid return code was received from an E35 exit routine. If an output data set was not present, the invalid code was other than 4 or 8, and SyncSort assumed return code 4. If end of file was reached, the invalid code was other than 8 or 12, and SyncSort assumed return code 8. WER227A ddname BLKSIZE GT ASCII LIMIT EXPLANATION: The ddname will be SORTOUT, SORTOFxx, SORTOFx or the ddname provided by an OUTFIL FNAMES parameter. The DD statement for an output data set targeted to an ASCII-labeled tape requested a blocksize greater than 2048 bytes; that violates the standard and cannot be done. WER228A ddname DCB BLKSIZE GT TRACK CAPACITY EXPLANATION: The ddname will be SORTOUT, SORTOFxx, SORTOFx or the ddname provided by an OUTFIL FNAMES parameter. The BLKSIZE for the indicated output file was greater than the track capacity of the output device. ACTION: Specifying the track-overflow RECFM in the DCB may possibly correct the error condition, or the BLKSIZE should be reduced. WER229A ddname DSORG NOT PS/PO EXPLANATION: The file defined by ddname must be a sequential data set (PS) or a partitioned data set (PO) member. WER230A [ddname] xxxxxxxx FIELD OUTSIDE RANGE EXPLANATION: The ddname will be SORTOUT, SORTOFxx, SORTOFx or the ddname provided by an OUTFIL FNAMES parameter. The reason for this may be any of the following:

Chapter 16. Messages

16.33

A field specified in the SORT/MERGE or JOINKEYS statement is not located within the first 32750 bytes of the variable-length record. (This limit is lower if AC, AQ, E, PD0, Y2x or LOCALE CH fields are used.) A field specified for INREC, OUTREC, OUTFIL OUTREC, REFORMAT, SECTION control, (SUB)TOTAL, (SUB)MIN, (SUB)MAX, (SUB)AVG or HEADER/TRAILER data field is located beyond the maximum record length. INREC, OUTREC, OUTFIL OUTREC, REFORMAT, or HEADER/ TRAILER n/col/date/page attempted to build a record larger than the allowable maximum. A REFORMAT statement referenced a join input file field, but records from that input file were excluded by specifying ONLY on the JOIN statement.

WER231A

[ddname] {INREC,OUTREC} - ILLEGAL DATA FIELD EXPLANATION: The ddname will be SORTOUT, SORTOFxx, SORTOFx or the ddname provided by an OUTFIL FNAMES parameter. An error was found in the INREC, OUTREC or OUTFIL OUTREC specification. ACTION: Check the statement for alphabetic data in a numeric field, for a parameter value of 0, for an omitted value, for a space value greater than 256X, for incorrect boundary alignment, and for inclusion of the "variable portion" of fixed-length input records in the output records. Also, LINES=ANSI or LINES=(ANSI,n) may not be used on the OUTFIL statement when using multi-line OUTREC.

WER232A

ddname RECFM=VBS, LRECL MISSING EXPLANATION: A RECFM of VBS was specified for the input ddname without an accompanying LRECL specification.

WER233A

VIO INVALID FOR DYNALLOC EXPLANATION: VIO is not permitted as a unit device for dynamic allocation. This is due to a possible performance degradation if VIO data sets are used as SORTWK.

16.34

SyncSort for z/OS 1.2 Programmers Guide

WER234I

DYNALLOC REQUEST FOR GT 32 SORTWKS EXPLANATION: A total of more than 32 work files were specified in both the JCL and the DYNALLOC parameter combined. The number was reduced to 32.

WER235A

[ddname] {INREC,OUTREC,REFORMAT} RDW NOT INCLUDED EXPLANATION: The ddname will be SORTOUT, SORTOFxx, SORTOFx or the ddname provided by an OUTFIL FNAMES parameter. Four bytes must be provided for the RDW of the variable-length output record in the FIELDS parameter of the INREC, OUTREC, OUTFIL OUTREC, or REFORMAT specification. These bytes must appear at the beginning of the record and must not be edited. For REFORMAT, the RDW must be specified as coming from a variable-length join input data set.

WER236A

[ddname] {INREC,OUTREC} NULL RECORD EXPLANATION: The ddname will be SORTOUT, SORTOFxx, SORTOFx or the ddname provided by an OUTFIL FNAMES parameter. A variable-length INREC, OUTREC or OUTFIL OUTREC output record must contain at least one other data field in addition to the RDW. Or if multi-line OUTFIL OUTREC is being used, at least one non-blank line must be defined.

WER237I

OUTREC RECORD LENGTH=xxxx EXPLANATION: The xxxx represents the length of the record after OUTREC processing. OUTREC occurs prior to E35 and/or SORTOUT/ OUTFIL processing. If the data consists of variable-length records, xxxx represents the maximum record length.

WER238I

POTENTIALLY INEFFICIENT USE OF INREC EXPLANATION: The INREC control statement has been used to increase the input record length. This can reduce SyncSorts performance because a larger volume of data is being processed than if the OUTREC control statement were used to perform the same function. Typically, increasing the record length with INREC is only useful when expanding SUM fields with leading zeros to prevent an overflow condition during SUM. ACTION: Revise the application so that addition of data is performed in an OUTREC statement. Be sure to adjust the FIELDS of the SORT, MERGE or SUM control statements if necessary.

Chapter 16. Messages

16.35

WER239A

TYPE PARAMETER REQUIRED EXPLANATION: There was a VSAM input or output file but the TYPE parameter was not specified. Or, an E15 or E32 exit routine is passing all of the records to the sort/merge (no SORTIN/SORTINnn), but the TYPE parameter was not specified on the RECORD control statement.

WER240A

ddname UNSUPPORTED DCB FUNCTION EXPLANATION: The DD statement specified or implied an attribute which is not supported, e.g., hardware keys for a disk output data set or a block prefix length other than 0, 4 or L for an ASCII tape output data set.

WER243I

SHORT RECORD FOR SUM EXPLANATION: One or more variable-length records were too short to contain all the sum fields specified on the SUM control statement. These records were therefore not summarized. Program HISTOGRM may be used to determine the length of the shortest record in the input file.

WER244A

[ddname] {INREC,OUTREC} SHORT RECORD EXPLANATION: The ddname will be SORTOUT, SORTOFxx, SORTOFx or the ddname provided by an OUTFIL FNAMES parameter. A variable-length record was too short to contain all the fields specified on the control statement. Program HISTOGRM may be used to determine the length of the shortest record in the input file.

WER246I

FILESIZE x EXPLANATION: The number of bytes of input data sorted or copied by SyncSort is given for FILESIZE. This number reflects SORTIN, E15, join, INCLUDE/OMIT, and INREC processing. Note the following: For MAXSORT, the FILESIZE is given in kilobytes for each individual sort in a WER351I message; the FILESIZE in the WER246I for the final merge is the sum of the individual sorts sizes and, because of truncation in each intermediate sort, may not be exact. When WER246I is issued instead of WER054I in a variable-length record copy operation, the number of bytes processed (copied) includes multiple segment descriptor words for a single record if the record is comprised of multiple segments on SORTIN, since all segments were copied; for a variable-length record sort or merge

16.36

SyncSort for z/OS 1.2 Programmers Guide

operation, the number of bytes processed (sorted or merged) includes a single record descriptor word for each record even if the record is comprised of multiple segments on SORTIN, since it is records, not record segments, that are being operated on. WER247A ddname HAS INCOMPATIBLE LRECL EXPLANATION: The ddname will be SORTOUT, SORTOFxx, SORTOFx or the ddname provided by an OUTFIL FNAMES parameter. There is a conflict between the LRECL specification for the indicated output file and either the post-OUTFIL or post-OUTREC record length. Padding of records is not permitted after OUTFIL processing, so the LRECL may not be greater than the post-OUTFIL record length. Alternately, truncation of records is not permitted after the OUTREC statement or the OUTFIL OUTREC processing, so the LRECL may not be less than the post-OUTREC record length. WER250A [ddname] INCLUDE/OMIT FIELD BEYOND RECORD EXPLANATION: The ddname will be SORTOUT, SORTOFxx, SORTOFx or the ddname provided by an OUTFIL FNAMES parameter. A compare field specified for INCLUDE, OMIT or OUTFIL INCLUDE/ OMIT extended beyond the end of the record. WER251A INCLUDE/OMIT INVALID yyyyyyyyyy EXPLANATION: The invalid relational condition represented by yyyyyyyyyy was found in the INCLUDE or OMIT specification. WER253A INCLUDE/OMIT FORMATS INCOMPATIBLE EXPLANATION: A relational condition specified on an INCLUDE or OMIT control statement, or in the INCLUDE or OMIT parameter of the JOINKEYS or OUTFIL control statement, contains an invalid field-tofield, field-to-constant or field-to-mask comparison. Note that if LOCALE processing has been specified, a CH to BI comparison is not supported. WER254A ddname VSAM {OPEN,CLOSE} ERROR - xx EXPLANATION: An error occurred during an attempt to OPEN or CLOSE a VSAM file defined by ddname. For the definition of the error number, xx, consult the following IBM publication: DFSMS Macro Instructions for Data Sets

Chapter 16. Messages

16.37

WER255A

VSAM LOGICAL ERROR xx ON {INPUT,OUTPUT} EXPLANATION: An error occurred while processing a VSAM data set. For the definition of the hexadecimal error number represented by xx, see one of the following IBM publications: DFSMS Macro Instructions for Data Sets

WER256I

ddname VSAM file, RECORDS PADDED ON OUTPUT EXPLANATION: The ddname will be SORTOUT, SORTOFxx, SORTOFx or the ddname provided by an OUTFIL FNAMES parameter. The fixed-length VSAM LRECL for the indicated output file is greater than the length of the records at the end of SyncSort processing. SyncSort padded the output records with filler characters on the right.

WER257I

INREC RECORD LENGTH=xxxxx EXPLANATION: xxxxx represents the length of the record immediately after INREC processing. If you have variable-length records, xxxxx represents the maximum record length.

WER258A

DUPLICATE DDNAME: SORTINxx EXPLANATION: Two input files for a merge have the same number. The file number is given.

WER259A

DUPLICATE ALTSEQ STATEMENT EXPLANATION: Two ALTSEQ control statements were found.

WER260I

RECOVERY FROM B37 SUCCESSFUL. SORT PROCESSING CONTINUES EXPLANATION: SyncSort recovered from a B37 abend and continued processing.

WER262I

REENTRANT SORT NOT RESIDENT - INEFFICIENT SORT EXPLANATION: The resident SyncSort load module(s) were loaded into the private area instead of being executed from the Link Pack Area/Extended Link Pack Area. This situation may have occurred because the module(s) were found in a STEPLIB/JOBLIB DD data set. Loading the resident modules into the private area limits the amount of virtual storage available to the sort and may reduce the efficiency of the sort.

16.38

SyncSort for z/OS 1.2 Programmers Guide

ACTION: Contact the systems programmer in charge of SyncSort installation. WER263A ILLEGAL USE OF MULTI-VOLUME SORTWK EXPLANATION: SyncSort does not support the use of multi-volume disk SORTWK data sets. (However, if SyncSort only requires the use of the space on the first volume of a multi-volume SORTWK file, this error message will not be issued.) ACTION: Remove the volume count subparameters of the UNIT parameter on all SORTWK DD statements that specify more than one volume. WER264A UNEQUAL REC LENS - VSAM SORTIN - TYPE=F EXPLANATION: A record in a fixed-length VSAM input data set was encountered whose length was not equal to the length specified in the RECORD statement or VSAM cluster definition. ACTION: Use the IDCAMS utility to identify and correct the records in error. WER265A ddname VSAM CONCATENATED INPUT NOT ALLOWED EXPLANATION: The ddname indicated represents an input file which consists of concatenated VSAM data sets. SyncSort does not support concatenated VSAM input files. WER266A ALTPARM - PARM LENGTH GT MAX SUPPORTED EXPLANATION: The length of the parameter list passed through the alternate parameter data set exceeded the 256 byte limitation. WER267A statement STATEMENT: STATEMENT NOT FOUND EXPLANATION: A required SORT/MERGE or RECORD statement (as indicated in the message text) is missing. WER268A statement STATEMENT: SYNTAX ERROR EXPLANATION: A SyncSort control statement, as indicated in the message text, contains a syntax error. The next line will contain an '*' indicating the approximate location of the syntax error.

Chapter 16. Messages

16.39

WER269A

statement STATEMENT: DUPLICATE STATEMENT FOUND EXPLANATION: More than one SORT/MERGE, INCLUDE/OMIT, INREC, OUTREC, RECORD, MODS, SUM, ALTSEQ or END statement was found, as indicated.

WER270A

statement STATEMENT: DUPLICATE PARM FOUND EXPLANATION: A single parameter was multiply specified on the indicated SyncSort control statement; or a single parameter was specified both in the invoking parameter list and in the control statements.

WER271A

statement STATEMENT: NUMERIC FIELD ERROR EXPLANATION: A numeric field has been improperly specified on the indicated SyncSort control statement.

WER272A

statement STATEMENT: PARMS NOT FOUND EXPLANATION: Required parameters have not been included on the indicated SyncSort control statement.

WER273A

BLANK STATEMENT FOUND EXPLANATION: A blank statement has been encountered.

WER274A

CONTINUATION STATEMENT ERROR FOUND EXPLANATION: SyncSort has encountered a statement containing a continuation indicator, but cannot locate a continuation statement which should follow.

WER275A

NO KEYWORDS FOUND ON CONTROL STATEMENT EXPLANATION: A required keyword has not been specified on a SyncSort control statement.

WER276B

SYSDIAG=nnnnnnnn,nnnnnnnn,nnnnnnnn,nnnnnnnn EXPLANATION: This message contains internal diagnostic information intended for use by SyncSort for z/OS Product Services.

WER300A

SORTBKPT DD STATEMENT REQUIRED EXPLANATION: The SORTBKPT DD statement was not included in the job stream. This is a required data set for all MAXSORTs.

16.40

SyncSort for z/OS 1.2 Programmers Guide

WER301A

SORTBKPT DATA MUST RESIDE ON DISK EXPLANATION: The SORTBKPT data set must be allocated to a disk device.

WER302A

SORTBKPT TRACK CAPACITY TOO SMALL EXPLANATION: Direct access devices with a track capacity smaller than 3600 bytes cannot be used for the SORTBKPT data set.

WER303A

SORTBKPT SYSTEM OPEN FAILURE EXPLANATION: The operating system could not open the SORTBKPT data set. ACTION: Check to see that the DD statement is correct. Determine if operating system is at proper maintenance level.

WER304A

SORTBKPT RECORD FORMAT ERROR EXPLANATION: There is a record format error in the SORTBKPT data set. ACTION: Check that the SORTBKPT DD statement points to the correct DSNAME. Check that the data set has not been inadvertently written into and modified. Use the HEX function on the OUTREC statement or OUTREC parameter on the OUTFIL statement to get a hex format listing of the data.

WER305A

SORTBKPT RECORD EXCEEDS BLKSIZE EXPLANATION: The use of an excessive number of parameters in a control statement has caused the SORTBKPT data set to overflow the maximum blocksize limit of 32760. ACTION: Reduce the size of the control statement specification if possible, or convert the application from a MAXSORT to a conventional sort.

WER306A

RESTART FROM BREAKPOINT PROHIBITED EXPLANATION: The SORTBKPT data set indicates that a programinitiated sort or a sort with exit programs tried to restart from a breakpoint. ACTION: Use z/OS checkpoint facilities since only these will save your work areas and the program memory for restart.

Chapter 16. Messages

16.41

WER307A

SORTBKPT RECORD SEQUENCE ERROR EXPLANATION: An out-of-sequence record was read from the SORTBKPT data set. ACTION: Use the HEX function on the OUTREC statement or OUTREC parameter on the OUTFIL statement to get a hexadecimal listing of the data set for analysis. See if the data set was damaged by another program. Check system for hardware error.

WER308A

BREAKPOINT ID NOT FOUND ON SORTBKPT EXPLANATION: The parameter RESTART=id was specified but id could not be found. ACTION: Check spelling, correct, and return.

WER309A

SORTOUXX DATA MUST BE ON DISK OR TAPE EXPLANATION: Intermediate sort output data was allocated to an unsupported device. Only disk or tape is allowed. ACTION: Allocate SORTOUxx data to either disk or tape.

WER310A

SORTOUXX DEVICE MIXING PROHIBITED EXPLANATION: Intermediate sort output was allocated to both tape and disk in the same job or to a mixture of disk device types. ACTION: Allocate all intermediate sort data to the same device type.

WER311A

DISK SORTOUXX REQUIRES SORTOUXX DD EXPLANATION: No SORTOUxx DD statements were found so there was no place to store intermediate sort output. ACTION: Supply one or more SORTOUxx DD statements with xx represented by 01 to 99.

WER312A

TAPE SORTOUXX REQUIRES SORTOU00 DD EXPLANATION: One or more SORTOUxx DD statements were allocated to tape but the SORTOU00 statement was not present. ACTION: Allocate a tape unit using the SORTOU00 DD statement.

16.42

SyncSort for z/OS 1.2 Programmers Guide

WER313A

SORTOUXX DEVICE NOT SUPPORTED EXPLANATION: The SORTOUxx DD statements specify an unsupported device type. ACTION: Change the device allocation of the SORTOUxx data set.

WER314A

INSUFFICIENT VIRTUAL STORAGE FOR MAXSORT EXPLANATION: MAXSORT cannot run efficiently in the amount of virtual storage provided. ACTION: Increase virtual storage or decrease the number of tape units requested by MINMERGE.

WER315A

SORTOUXX BLKSIZE GT TRACK CAPACITY EXPLANATION: Intermediate sort output is on disk, but the SORTIN data set requires too large a blocksize for a disk device. ACTION: Allocate intermediate sort output to tape and rerun.

WER316A

INSUFFICIENT SORTOUXX DD STATEMENTS EXPLANATION: The data to be sorted requires one or more additional data sets. ACTION: Recalculate and restart the job including additional SORTOUxx DD statements. (Make sure each statements number is greater than the last one you put in.)

WER317I

MAXSORT OPTION SELECTED EXPLANATION: A MAXSORT was requested.

WER318I

INPUT CARDS IGNORED - SORTBKPT USED EXPLANATION: The control statement just listed on SYSOUT for a breakpoint restart were not used to control sorting. Whatever control statements were specified when the job was started were used. (They may be the same as the statements just listed, however.)

WER319I

SORT RESTARTED AT BKPT xxxxxxxxxxxx EXPLANATION: This message identifies the breakpoint id from which MAXSORT resumes execution on a breakpoint restart.

Chapter 16. Messages

16.43

WER320I

INEFFICIENT SORTOUXX BLKSIZE FORCED EXPLANATION: Due to the constraints between the amount of memory and the value specified for MAXMERGE, MAXSORT was forced to compromise and choose a smaller blocksize than would permit efficient buffering in sorts and merges. ACTION: If you wish a more efficient MAXSORT, either increase the amount of memory or reduce the number specified for MAXMERGE. This will permit a larger blocksize to be chosen which will allow multiple buffering of all the intermediate sort output data.

WER321B

SORTOUXX BLKSIZE=xxxxx EXPLANATION: This gives the blocksize that MAXSORT has chosen for intermediate sort output.

WER322A

TAPE DYNALLOC FAILURE - CODE=xxxx EXPLANATION: Attempts to dynamically allocate tape units for a merge phase met with unexpected failure. Code xxxx gives the hexadecimal return code from the dynamic allocation request. For an explanation of this code, see either IBM publication z/OS MVS Programming: Authorized Assembler Services Guide SA22-7608 or OS/390 V2R10.0 MVS Authorized Assembler Service Guide GC28-1763.

WER323A

BKPT DATA AT DIFFERENT RELEASE LEVEL EXPLANATION: The SORTBKPT data was created by a different SyncSort release than the SyncSort program reading it. Because of this, the breakpoint data cannot be processed. ACTION: Restart this job and run under the same SyncSort release that you started with.

WER324A

TAPENAME CLASS NOT FOUND ON SYSTEM EXPLANATION: The tapes could not be dynamically allocated because a TAPENAME was specified that was not generated into the operating system. ACTION: Check with the systems programmer for acceptable unit names.

16.44

SyncSort for z/OS 1.2 Programmers Guide

WER325A

MAXSORT STOPPED BY OPERATOR EXPLANATION: The operator responded to a message by stopping the sort. The sort may be restarted from the last breakpoint or checkpoint.

WER326A

DYNALLOC UNALLOC FAILURE - CODE=xxxx EXPLANATION: Attempts to dynamically deallocate tape units met with unexpected failure. Code xxxx gives the hexadecimal return code from the dynamic deallocation request. For an explanation of this code, see either IBM publication z/OS MVS Programming: Authorized Assembler Services Guide SA22-7608 or OS/390 V2R10.0 MVS Authorized Assembler Service Guide GC28-1763.

WER327A

INSUFFICIENT UNITS FOR MINIMAL MERGE EXPLANATION: Too few tape units were allocated to meet the number specified in MINMERGE. Either too few SORTOUxx DD were supplied or the z/OS system was unable to dynamically allocate enough units. ACTION: Restart the job with additional SORTOUxx DD statements.

WER328A

SORTOUXX SYSTEM OPEN FAILURE EXPLANATION: The operating system could not open the SORTOUxx data sets. ACTION: Check to see that SORTOUxx DD statements are correct. Determine if operating system is at a proper maintenance level.

WER329A

SORTOU00 SYSTEM RDJFCB FAILURE EXPLANATION: The operating system could not read the Job File Control Block for SyncSort analysis. ACTION: Determine if operating system is at a proper maintenance level.

WER330A

SPECIFIED SORTING TIME HAS EXPIRED EXPLANATION: The time limit specified in the SORTTIME parameter has expired. The job may be restarted from the last breakpoint or checkpoint.

WER331A

SYSTEM CHECKPOINT FAILURE EXPLANATION: Request for z/OS checkpoint facilities failed.

Chapter 16. Messages

16.45

ACTION: Ascertain that the SORTCKPT DD statement was correctly specified. Check that rules for the use of checkpoint were not violated. WER332A TOO MANY INTERMEDIATE SORTS - INCREASE SORTWORK SPACE EXPLANATION: Only 99 intermediate sorts are allowed in a MAXSORT application. ACTION: Increase the SORTWORK space available to MAXSORT so that each intermediate sort will process more data, reducing the number of intermediate sorts required. Ensure that the MINWKSP and MAXWKSP values are sufficient to allow additional space to be acquired. The application does not have to be restarted from the beginning. If a MAXSORT breakpoint restart is allowed in the application, restart from an earlier breakpoint with a sufficient amount of SORTWORK space available to process the file within the 99 intermediate sort limit. WER350I {SORT/MERGE} # XX COMPLETE {AT BREAKPOINT/AT CHECKPOINT} bbbbbbbbbbbb, DIAG=hhhh,hhhh... EXPLANATION: This message tells which individual sort or merge has completed. Restart can be performed from the breakpoint or checkpoint id given in bbbbbbbbbbbb. If restart is not possible the above message will read: SORT/MERGE # XX COMPLETE. The hexadecimal information following the DIAG keyword is likely to change from execution to execution. It is internal diagnostic information intended for use by SyncSort personnel in Product Support. WER351I DATA SIZE xxxx KB [FROM yy WAY MERGE] EXPLANATION: The amount of data that was processed for the current SyncSort individual sort/merge is given in kilobytes. When a merge is processed yy gives the number of tape units used. WER352I DYNAMICALLY ALLOCATED TAPE UNITS - XX EXPLANATION: The number of tapes drives that were dynamically allocated for the current merge pass is given. WER353I STARTING TIME hh.mm.ss - ENDING TIME hh.mm.ss EXPLANATION: The starting and ending times in hours, minutes, and seconds of the individual sort or merge just completed are given.

16.46

SyncSort for z/OS 1.2 Programmers Guide

WER354I

----------------------DATA SET STATUS---------------------EXPLANATION: This is a header. Messages relating to data sets will follow.

WER355I

{DSN=dsname/VOL SERS = vvvvvv...} EXPLANATION: The data set names of the tapes for intermediate sort output are given. The tape volumes are listed for tape intermediate sort output. Retain these reels for input to a later merge.

WER356I

SORTOUXX DD STATEMENT IS ACTIVE EXPLANATION: The disk data set allocated to the SORTOUxx DD statement is needed as input to a subsequent merge. Be sure to keep it in case restart is necessary.

WER375D

jobname.stepname - MAXSORT BKPT id TIME ESTIMATE: XXX MINUTES UNTIL NEXT NOTIFICATION. REPLY 'GO' TO CONTINUE, 'STOP' TO TERMINATE EXPLANATION: A long-running MAXSORT has exhausted its assigned block of computer time. ACTION: The operators decision should be based on scheduling priorities and the estimated time of the sort. A 'GO' reply will permit sort execution to proceed in stages. This message is generated at discrete intervals so that the operator can again opt to continue or terminate its execution.

WER376D

jobname.stepname - MAXSORT BKPT id aaa TAPE UNITS ALLOCATED TO jobname bbb TAPE UNITS NEEDED FOR BEST PERFORMANCE TIME ESTIMATE USING aaa TAPE UNITS xxxx MINUTES TO {NEXT BREAKPOINT | END OF JOB} REPLY 'GO' TO CONTINUE, 'STOP' TO TERMINATE, 'NN' # UNITS EXPLANATION: The first time this message is generated, it indicates that MAXSORT has dynamically allocated the optimum number aaa of tape drives up to MAXMERGE. Reissued, this message documents MAXSORTs response to the operators previous reply of 'NN' tape units. 'NN' represents the total number of tapes that will be allocated. ACTION: Given a reply of 'NN' tape drives, MAXSORT will attempt to satisfy the operators request. For 'NN' larger than aaa, MAXSORT will

Chapter 16. Messages

16.47

try to raise its allocation to 'NN'. (The operator can delay the request for more tape units in order to give other jobs time to free any tape drives they are using.) The above message is reissued and the operator can see how the decision will affect sort execution. As soon as allocations and time estimates are satisfactory, the reply 'GO' will cause continued execution using the allocated tape units. If allocation or time estimates are not satisfactory, the job may be terminated (reply 'STOP') or a new number 'NN' of units may be requested. WER377D jobname.stepname - MAXSORT BKPT id INSUFFICIENT TAPE UNITS AVAILABLE aaa TAPE UNITS ALLOCATED TO jobname bbb TAPE UNITS NEEDED TO CONTINUE EXECUTION REPLY 'RETRY' TO GET UNITS, 'STOP' TO TERMINATE EXPLANATION: MAXSORT cannot immediately acquire enough tape drives to make continued processing worthwhile. ACTION: The operator can wait until other tape drives have been released, then reply 'RETRY'. If enough drives are now available, execution continues. Otherwise the above message is repeated. Eventually enough tape drives become available or the operator terminates the job with a 'STOP' response. WER378I NO ADDITIONAL TAPE UNITS EXIST FOR GENERIC CLASS tapename EXPLANATION: All tape units on the system within the TAPENAME class have been allocated. Further DYNALLOC attempts will fail to acquire more tape units. Message WER376D or WER377D will follow. WER390A MINIMUM SORTWK SPACE NOT AVAILABLE EXPLANATION: MAXSORT could not obtain enough SORTWK disk space to run. When MAXSORT is executing with larger storage values, SyncSort may need to automatically raise MINWKSP, overriding the specified MINWKSP value. Therefore, it may erroneously appear that JCL SORTWKs provided enough space to satisfy MINWKSP when this message was posted. ACTION: Correct SORTWK volume, primary, and secondary allocations. Restart the job.

16.48

SyncSort for z/OS 1.2 Programmers Guide

WER391A

INSUFFICIENT VIRTUAL STORAGE FOR SORTBKPT BUFFER EXPLANATION: MAXSORT was unable to obtain the necessary 3600byte buffer space from the operating system. ACTION: Check to see that sufficient virtual storage was allocated to the sort.

WER392A

SORTBKPT FORMAT ERR - VBS PROCESSING EXPLANATION: MAXSORT attempted to read back control information associated with VBS SORTIN data and found a format error in the SORTBKPT data set. ACTION: In the U.S. and Canada, call SyncSort for z/OS Product Services directly at (201) 930-8260. Elsewhere, call your SyncSort support representative.

WER393I

TURNAROUND MAXSORT SORT PERFORMED EXPLANATION: The amount of SORTIN data was small enough to fit entirely on SORTWK disk space, so sorted data was produced in one SyncSort pass.

WER394A

SORTOUXX DD STMT REQUIRED FOR MERGE EXPLANATION: The above DD statement was required for disk intermediate sort output as input to a merge but could not be found. ACTION: Supply the missing DD statement.

WER395A

INVALID SORTOU00 OR SORTOUxx DSN PREFIX EXPLANATION: The BKPTDSN parameter was used, but the required trailing period was not specified as part of the DSN prefix. ACTION: Add a trailing period to the parameter specification.

WER396A

LKED DD STATEMENT MISSING OR INVALID EXPLANATION: A MODS statement specified at least one exit to be link-edited by SyncSort, but a SYSPRINT and/or SYSLIN and/or SYSLMOD DD statement is missing. All of these statements are required for link-editing. Or, the SYSLMOD DD statement does not refer to a data set on a direct access device.

Chapter 16. Messages

16.49

ACTION: Supply the missing DD statement(s) or adjust the SYSLMOD DD statement as appropriate. WER400A ddname IS AN UNINITIALIZED SEQUENTIAL DISK DATA SET EXPLANATION: The input data set was allocated but never opened for output. Therefore, there is no valid data or end-of-file mark in the data set. This condition usually occurs when a program abends and the steps to create the data are bypassed. ACTION: Write the appropriate data or end-of-file mark in the data set. WER401A CSECT NAME DIFFERENT THAN MEMBER NAME EXPLANATION: The MODS statement specified an exit routine module in SYSIN that was not found. ACTION: Either change the member name in the MODS statement to match the module name or reassemble the exit module with a name to match the member name on the MODS statement. WER402A SORTMODS STOW FAILURE EXPLANATION: While copying an exit routine from SYSIN to SORTMODS, SyncSort attempted unsuccessfully to store (STOW) the exit routine in the SORTMODS directory. This condition is caused either by specifying insufficient directory blocks when creating the SORTMODS data set or by the presence of a member or alias with the same name as the exit routine in the SORTMODS data set, or by a hardware failure. ACTION: Check the SORTMODS directory names for a member-name conflict and rerun the job step. WER403A OUTFIL NOT VALID FOR MAXSORT EXPLANATION: Using an OUTFIL control statement in a MAXSORT application is not supported at this time. ACTION: Either remove the OUTFIL statement(s) or convert the application not to invoke MAXSORT. WER404I SORTXSUM: RECFM= ;LRECL= ;{BLKSIZE=,CISIZE=} [;CINV ACCESS]; RCD OUT n EXPLANATION: This informational message lists the DCB characteristics used by SyncSort to process the SORTXSUM file, as well as the number of records (n) that were written to the data set. For a VSAM

16.50

SyncSort for z/OS 1.2 Programmers Guide

data set, the CISIZE is provided; if control interval access was used, the CINV ACCESS portion of the message will be displayed. WER405I ddname DATA RECORDS OUT n, TOTAL RECORDS OUT y EXPLANATION: The ddname will be SORTOUT, SORTOFxx, SORTOFx or the ddname provided by an OUTFIL FNAMES parameter. The n represents the number of data records (exclusive of HEADERS/ TRAILERS and multi-record OUTREC) in each output data set. The y represents the total number of records in each output data set (data records, HEADERS/TRAILERS and multi-record OUTREC records). Note that the total number of lines written to the line printer may be greater than the actual record count since multiple lines can be generated from one data record using ANSI control characters. WER406A ddname HEADER/TRAILER/DATA LINES EXCEED PAGE SIZE EXPLANATION: The ddname will be SORTOUT, SORTOFxx, SORTOFx or the ddname provided by an OUTFIL FNAMES parameter. The number of lines generated by some HEADER and/or TRAILER and/or multi-line OUTREC parameters is greater than or equal to the number of lines to be written per logical page as specified by the LINES parameter. If LINES has not been coded, this number defaults to 60. ACTION: Reduce the number of HEADER/TRAILER lines generated or increase the number of lines in the LINES parameter so that a minimum of all output lines from 1 data record can be written per logical page. WER407I UNUSABLE SORTWK DEVICE ALLOCATED {,NON RPS,UNIT=VIO} EXPLANATION: An unusable device was allocated during dynamic allocation. The device was held for the duration of the sort; however, the device was not used for SORTWK storage. ACTION: For future executions, ensure that the DYNALLOC runtime parameter specifies a correct disk device. If the message cites "NON RPS," specify RPS disk devices; if the message cites "UNIT=VIO," specify a true disk device. WER409A MOD ON SYSIN NOT FLAGGED AS SYSIN MODULE EXPLANATION: An object deck was found in the SYSIN data set that, according to the MODS statement, was not specified as belonging in SYSIN.

Chapter 16. Messages

16.51

WER410B

xxx BYTES OF VIRTUAL STORAGE AVAILABLE ABOVE THE 16MEG LINE, yyy BYTES RESERVE REQUESTED, zzz BYTES USED EXPLANATION: The amount of virtual storage above the 16-megabyte line available (free) when SyncSort received control is represented by xs. The amount of virtual storage that the user requested SyncSort to reserve above the 16-megabyte line is represented by ys. The amount of virtual storage used by SyncSort above the 16-megabyte line is represented by zs.

WER411B

nnn BYTES OF EMERGENCY SPACE ALLOCATED ABOVE THE 16MEG LINE EXPLANATION: The indicated amount of virtual storage above the 16megabyte line has been set aside by SyncSort for use by other programs (e.g., program invoking the sort, system SVCs, tape management system.)

WER412I

ERROR TAKING SYSTEM CHECKPOINT. PROCESSING CONTINUES EXPLANATION: An error occurred when SyncSort attempted to take a user-requested checkpoint. Sort/merge processing continued; however, a usable checkpoint may not exist. Refer to the IHJxxxx message in the job log to determine the cause of the error.

WER414A

ddname OPEN ERROR ON AN UNINITIALIZED SEQUENTIAL DISK DATA SET EXPLANATION: An error occurred during an OPEN of a multi-volume uninitialized sequential disk data set being used for ddname. When the UNINTDS=YES option has been selected, either by default or parameter override, SyncSort will need to open for output a multi-volume uninitialized disk data set in order to set the DS1IND80 flag in the format-1 DSCB of the first volume. Typically this error will occur if the SyncSort step does not have the authority to open the data set for output processing. ACTION: In a separate step prior to the SyncSort invocation, write the appropriate end-of-file mark in the first volume of the multi-volume data set.

WER415B

DSM FACILITY DISABLED EXPLANATION: SyncSorts dynamic storage management feature was not active for this sort execution.

16.52

SyncSort for z/OS 1.2 Programmers Guide

WER416B
access-method WAS USED FOR ddname ddname: EXCP'S=eee [,UNIT=uuuu] [,DEV=dddd] [,CHP=cccccccc,n][,VOL=vvvvvv] TOTAL OF xxx EXCP'S ISSUED FOR totalid

EXPLANATION: This message provides summary I/O tuning information for files processed by SyncSort. The first form is used when an access method other than EXCP is used for a file. It uses a generic term for the access method (BSAM, HIPERBATCH, etc.) and the file for which it was used. When EXCP is used, the message takes on the second form which has the component parts listed below. Some of these components may or may not be included in the message depending on the level of the operating system and the availability of the information within SyncSort. EXCP'S=eee "eee" identifies the number of EXCPs issued for the file. For input files such as SORTIN, this is the total EXCPs issued for all concatenated input sets. "uuuu" is the unit type on which the data set resides. For files that can consist of concatenations or multi-volume data sets, the unit type displayed is for the first volume of the first data set. "dddd" is the device name for the first or only device for the file. This field identifies the channel paths available to the first or only device. ''n'' is the number of PAV aliases available. This field is displayed for only DASD devices and identifies the volume serial number of the first or only volume for the file.

UNIT=vuuuu

DEV=dddd

CHP=cccccccc,n

VOL=vvvvvv

For certain types of sorts, SyncSort may dynamically allocate data sets other than SORTWKxx data sets for use in the sorting process, and this can occur whether or not normal dynamic allocation of sortwork data sets is enabled. When used, such data sets are collectively represented in a single WER416B message using a ddname of "SORTWK&&" for the purpose of reporting EXCPs issued against them. In the third form of the message, xxx provides a total of the EXCPs issued for SORTWORKS, SORTING, COPYING, or MERGING, as identified by "totalid."

Chapter 16. Messages

16.53

WER417A

UNEQUAL MAINTENANCE LEVELS: xxxxxxxx,yy,zz EXPLANATION: The load module xxxxxxxx and SyncSort root module maintenance levels do not correspond. yy represents the maintenance level of the xxxxxxxx module; zz represents the maintenance level of the root module. ACTION: Contact the systems programmer in charge of SyncSort maintenance.

WER418I

DATASPACE(S) AND/OR xxxxxxxx USED EXPLANATION: xxxxxxxx can be either ZSPACE or HIPERSPACE(S). SyncSort has dynamically chosen to use data space, ZSPACE, or hiperspace during the execution of the sort. ZSPACE is a technique within SyncSort created as a replacement for hiperspace. It allows native use of the central storage resources which are available. This technique eliminates the additional overhead produced when hiperspace is simulated by the operating system in a z/Architecture environment. It provides superior CPU performance and reduced system overhead compared to a conventional hiperspace application.

WER420I

COBOL ACCELERATOR ACTIVE EXPLANATION: SyncSorts high performance access method was used for accessing a COBOL file.

WER422A

SORTOUT STOW FAILURE EXPLANATION: When writing to SORTOUT, SyncSort attempted unsuccessfully to store (STOW) the SORTOUT PDS member in the SORTOUT directory. This condition is caused by specifying insufficient directory blocks when creating the SORTOUT data set. ACTION: Recreate the SORTOUT data set with more directory blocks and rerun the job step.

WER423I

DYNAMIC ALLOCATION RETRY - WAITING FOR SPACE EXPLANATION: The DYNALLOC facility is being used to acquire sortwork space, but there is currently insufficient disk space on the system to satisfy the request. SyncSort will wait the prescribed number of minutes as specified by the DYNALLOC option and then retry the request.

16.54

SyncSort for z/OS 1.2 Programmers Guide

WER424I

DYNAMIC ALLOCATION RETRY SUCCESSFUL EXPLANATION: The dynamic allocation of sortwork space after a DYNALLOC RETRY attempt was successful. Sort processing continues.

WER426I

SORT INTERNAL ERROR - RECOVERY ATTEMPT IN PROGRESS EXPLANATION: The presence of this message indicates that an automatic retry of the SyncSort execution has been initiated. If the error recovery is successful, the SyncSort SYSOUT listing will contain a subsequent set of messages representing the complete information about the execution. The subsequent set of messages may be separated from the initial set of listings by a diagnostic output of significant size. The new listing will contain the message WER427I.

WER427I

RECOVERY ATTEMPT IN PROGRESS EXPLANATION: The set of SYSOUT messages containing the WER427I will be from the automatic retry execution. Examine these messages to insure that it also contains a WER052I message indicating a successful completion of the SyncSort execution. In addition, a successful SyncSort recovery will complete with a return code of zero. Even if the WER426I and WER427I messages are present, this in itself does not constitute a successful recovery unless zero is returned for the step completion code. If an execution of SyncSort does utilize the recovery facility, whether successfully or not, the SyncSort for z/OS Product Services Group should be contacted so that the underlying error can be investigated and resolved.

WER428I

CALLER-PROVIDED IDENTIFIER IS "xxxx" EXPLANATION: SyncSort was invoked by another program, and that program used a 31-bit parameter list where the "call identifier" parameter was specified. xxxx is the identifier specified by the calling program.

WER429I

SORT INTERNAL ERROR ON SORTWKxx - RECOVERY ATTEMPT IN PROGRESS EXPLANATION: An internal error occurred while processing the SORTWK data set indicated by nn. The presence of this message indicates that SyncSort has initiated automatic error retry logic to correct this error. If the recovery is successful, processing will resume and mes-

Chapter 16. Messages

16.55

sage WER052I will be issued when the sort has completed successfully. Absence of the WER052I message indicates that SyncSort was unable to recover. ACTION: If an execution of SyncSort does use this recovery facility, whether successfully or not, SyncSort for z/OS Product Services should be contacted so that the underlying condition can be investigated and resolved. WER430I SORT INTERNAL ERROR ON SORTOUT - RECOVERY ATTEMPT IN PROGRESS EXPLANATION: An internal error occurred while creating the SORTOUT data set. The presence of this message indicates that SyncSort has initiated automatic error retry logic to correct this error. If the recovery is successful, processing will resume and message WER052I will be issued when the sort has completed successfully. Absence of the WER052I message indicates that SyncSort was unable to recover. ACTION: If an execution of SyncSort does use this recovery facility, whether successfully or not, SyncSort for z/OS Product Services should be contacted so that the underlying condition can be investigated and resolved. WER431I COPY SUBSTITUTED FOR MULTIPLE OUTFILS EXPLANATION: The SORT or COPY multiple output application (multiple OUTFILs) has been automatically converted by SyncSort to a single SORT or COPY operation followed by one or more COPY operations. If system resources are available and the output files of a multiple output application have identical specifications, SyncSort will make this type of change to take advantage of system resources to improve the applications performance. WER432I {SORT,MERGE} FORMAT OPERAND IGNORED EXPLANATION: On either a SORT or MERGE control statement, the format of the keys was specified in both the FIELDS and FORMAT parameters. SyncSort ignores the FORMAT parameter and uses the individual format specifications within the FIELD parameter. WER433I SUM FORMAT OPERAND IGNORED EXPLANATION: On a SUM control statement, the sum field format was specified in both the FIELDS and FORMAT parameters. SyncSort

16.56

SyncSort for z/OS 1.2 Programmers Guide

ignores the FORMAT parameter and uses the individual format specifications within the FIELD parameter. WER435A SORTIN(nn) ALLOCATION ERROR ON AN UNINITIALIZED SEQUENTIAL DISK DATA SET EXPLANATION: An error occurred during the dynamic allocation of a multi-volume uninitialized sequential disk data set being used for an input data set. When the UNINTDS=YES option has been selected, either by default or parameter override, SyncSort will need to dynamically allocate and open for output a multi-volume uninitialized disk data set in order to set the DS1IND80 flag in the format-1 DSCB of the first volume. ACTION: In a separate step prior to the SyncSort invocation, write the appropriate end-of-file mark in the first volume of the multi-volume data set. WER436I UNEQUAL MAINTENANCE APPLIED TO GLOBAL DSM AND SYNCSORT LIBRARIES EXPLANATION: The maintenance level of the SyncSort for z/OS product is in conflict with the maintenance level of the global DSM (GDSM) subcomponent due to the incomplete application of one or more maintenance levels. WER437A [ddname] SPLIT, SPLITBY, OR REPEAT INCOMPATIBLE WITH REPORT WRITING EXPLANATION: The ddname will be SORTOUT, SORTOFxx, SORTOFx or the ddname provided by an OUTFIL FNAMES parameter. The SPLIT, SPLITBY, or REPEAT parameter and one or more report writing parameters have been specified for an OUTFIL group. The specified ddname is the first ddname of the OUTFIL group. SPLIT, SPLITBY, or REPEAT and report writing parameters are incompatible on the same OUTFIL control statement. Specifically, SPLIT, SPLITBY, or REPEAT cannot be specified on the same OUTFIL statement with HEADERn, TRAILERn, LINES, NODETAIL, and SECTIONS. WER438A [ddname] {INREC,OUTREC} - NONE OF THE FINDCONSTANTS WAS MATCHED WITH THE CHANGE FIELD (p,l), CONTENTS OF INPUT FIELD IN HEX: xxxxxxxx EXPLANATION: The ddname will be SORTOUT, SORTOFxx, SORTOFx or the ddname provided by an OUTFIL FNAMES parameter. A CHANGE subparameter on an INREC, OUTREC or OUTFIL OUTREC control statement was specified without a NOMATCH option and

Chapter 16. Messages

16.57

the input field did not match any of the specified find-constants. p,l represents the position and length of the input field. xxxxxxxx is the hexadecimal representation of the input field. WER440A UNSUPPORTED OPERATING ENVIRONMENT EXPLANATION: The operating system on which SyncSort for z/OS executes must be OS/390 or later. In addition, SyncSort for z/OS can only be used on the following class of IBM and compatible servers: IBM S/390 Parallel Enterprise Server models except Release 1 models. IBM S/390 Multiprise models IBM PC Server S/390 servers and RS/6000 with S/390 Server-onBoard models. IBM S/390 Integrated Servers IBM zSeries models

WER441A

ERROR IN CALLING LANGUAGE ENVIRONMENT SERVICE, RC = nnnn EXPLANATION: A Language Environment service used to support LOCALE processing indicated a critical error in its feedback code. nnnn is the error message number representing the feedback code. For an explanation of this code, see the IBM publication Debugging Guide and Run-Time Messages, SC26-4829.

WER442A

INVALID CHARACTER IN COMPARE FIELD FOR ACTIVE LOCALE EXPLANATION: INCLUDE/OMIT processing with the LOCALE function active detected a character that is not defined in the current locale. The invalid character could be in a CH field or in a character or hexadecimal constant compared to a CH field.

WER443A

INVALID CHARACTER IN CONTROL FIELD FOR ACTIVE LOCALE EXPLANATION: Sort or merge processing with the LOCALE function active detected a character that is not defined in the current locale. The invalid character is in a CH sort or merge field.

16.58

SyncSort for z/OS 1.2 Programmers Guide

WER444I

LOCALE PROCESSING USED FOR LOCALE nnnnnn EXPLANATION: Indicates that LOCALE processing was in effect. nnnnnn (up to 32 characters) represents the name of the locale used.

WER445A

LOCALE PROCESSING CONFLICT EXPLANATION: LOCALE processing has been used illegally. LOCALE processing cannot be used with an E61 exit. The LOCALE specification cannot be changed on a MAXSORT breakpoint restart.

WER446A

[ddname] INCLUDE/OMIT FORMATS INCOMPATIBLE FOR LOCALE PROCESSING EXPLANATION: The ddname will be SORTOUT, SORTOFxx, SORTOFx or the ddname provided by an OUTFIL FNAMES parameter. LOCALE processing has been requested and a character (CH) to binary (BI) comparison was specified on an INCLUDE/OMIT statement or OUTFIL INCLUDE/OMIT parameter. CH to BI comparisons are not supported when using LOCALE processing.

WER447B

PHASE 3 VIRTUAL STORAGE REDUCED TO nnn BYTES FOR OPTIMAL PERFORMANCE EXPLANATION: Phase 3 optimization has determined that a reduction in virtual storage is appropriate for an efficient execution. nnn is the amount of virtual storage used during phase 3. The total bytes used value in message WER164B indicates the virtual storage used during earlier phases of the sort execution.

WER448I

Y2 FORMAT CENTURY WINDOW IS FROM xxxx TO yyyy EXPLANATION: One of the Y2x data formats has been used for a SORT/MERGE field, an INCLUDE/OMIT field or an INREC/OUTREC edit field. The starting year is xxxx and the ending year is yyyy for the century window used to process the fields.

WER449I

SYNCSORT GLOBAL DSM SUBSYSTEM ACTIVE EXPLANATION: The SyncSort Global DSM (GDSM) subsystem was active during the execution of this SyncSort application.

WER450I

PARASORT USED EXPLANATION: The PARASORT technique has been used for this execution.

Chapter 16. Messages

16.59

WER451A

PARASORT TAPE LABEL ERROR VOL(vvvvvv) [CONCATENATION+0nnn] EXPLANATION: The tape label on volume vvvvvv does not match the DCB characteristics of the SORTIN data set. This could happen because of changed record length, BLKSIZE or recording format. This situation is normally caused by overwriting some of the data in a multivolume data set. The concatenation number indicates where in the SORTIN concatenation the volume in error may be found.

WER452I

PARASORT NOT USED: reason EXPLANATION: The PARASORT feature has been disabled and the sort was performed using conventional SORTIN processing. The message indicates the reason for this action, which may be any of the following: AUTOMATIC RETRY DISABLED Automatic sort retry must be enabled for PARASORT to be used. It is required in the event that the condition identified in WER454A is encountered. CONCATENATED SORTIN DEVICES DIFFER Concatenated SORTIN devices must be the same device; that is, unit affinity must be specified. DUPLICATE VOLUMES ON SORTIN DD NOT ALLOWED INCOMPATIBLE CONDITIONS The application may specify elements that cannot be used together. This problem can be caused by unusual sort key types, some feature combinations, or very long sort keys. INPUT IS NOT TAPE PARASORT requires input from tape devices. Input from any other source is not permitted. INSUFFICIENT TAPE CHANNELS At least two channel paths must be available to the tape drives being used to read the SORTPARn DDs. For a description of a technique to help insure that this requirement is satisfied, see the description of esoteric unit names in the PARASORT chapters of this manual and the SyncSort for z/OS Installation Guide. NO SORTWORKS AVAILABLE PARASORT requires sortwork space, which must be specified in the JCL or provided dynamically by DYNALLOC. RETRY IN PROGRESS PARASORT failed, but a retry is being attempted. SORTIN IS A NULLFILE SORTIN IS ONLY A SINGLE VOLUME DATA SET The SORTIN DD statement for PARASORT must define either a single multi-volume SORTIN data set or several concatenated tape data sets, which can be single or multi-volume. One single-volume data set is not permitted.

16.60

SyncSort for z/OS 1.2 Programmers Guide

V(B)S DATA SETS NOT ALLOWED VS and VBS data sets are not compatible with PARASORT.

WER453A

FOR PARASORT text EXPLANATION: PARASORT failed and the sort application will not execute. The message text indicates the condition that caused the failure or the PARASORT requirement that was violated: A SORTPAR2 DD STATEMENT IS REQUIRED EQUALS MAY NOT BE SPECIFIED If EQUALS is not specified on the SORT control statement or as a PARM, ensure it is not enabled by default. Pass NOEQUALS to disable EQUALS. E15 EXITS MAY NOT BE SPECIFIED MAXSORT MAY NOT BE SPECIFIED PASSED SORTIN IS INVALID SEQNUM MAY NOT BE SPECIFIED ON INREC SKIPREC MAY NOT BE SPECIFIED SORTIN AND SORTOUT MUST BE DIFFERENT DATA SETS SORTIN GDG NOT ALLOWED SORTIN VOLUME SEQUENCE MAY NOT BE SPECIFIED The volume sequence number must be 1, the first volume. The number cannot be greater than 1. SORTPAR DD STATEMENTS ARE REQUIRED SORTPAR(N)S MUST BE SEQUENTIALLY NUMBERED SORTPAR1 AND SORTIN DATA SET NAMES MUST BE THE SAME SORTPAR1 DISPOSITION MUST BE OLD SORTPAR1 UNIT MUST BE THE SAME AS THE SORTIN UNIT SORTPAR1-4 DEVICE TYPES MUST BE THE SAME AS THE SORTIN DEVICE TYPE SORTPAR2-4 CANNOT BE THE SAME AS THE SORTIN UNIT SORTPAR2-4 and SORTIN DATA SET NAMES MUST BE THE SAME SORTPAR2-4 DISPOSITION MUST BE (NEW,KEEP,KEEP) SORTPAR2-4 MUST SPECIFY DEFER ON THE UNIT PARAMETER SORTPAR2-4 MUST SPECIFY VOL=PRIVATE STOPAFT MAY NOT BE SPECIFIED THE DISPOSITION OF SORTIN IS INVALID SORTIN data sets may not be temporary data sets. They also may not be NEW, passed or have PASS on their JCL definition. DB2 MAY NOT BE SPECIFIED The DB2 query function is not supported with a PARASORT.

Chapter 16. Messages

16.61

WER454A

PARASORT SORTIN END OF FILE ENCOUNTERED BEFORE THE VOLUME LIST EXHAUSTED EXPLANATION: The SORTIN volume list is supplied from either the catalog or specific list of volume serial numbers. The volume serial list must accurately reflect the volumes in the data set. If extra volumes are specified (as may happen if an old data set is rewritten with less data) this error message will be generated. A volume sequence number may not be specified.

WER455I

PARASORT CHANNEL CONTENTION - SORTPARn NOT USED EXPLANATION: SORTPAR2-4 has no available channel path to send data other than a path that would conflict with a previously defined SORTPARn definition. This SORTPARn will not be used during the PARASORT execution. This message may occur more than once if there are multiple conflicting SORTPARn DDs.

WER456I

VISUAL SYNCSORT APPLICATION SUCCESSFULLY EXPORTED EXPLANATION: A file that describes your application has been created and written to the VISUALEX DD statement for export to Visual SyncSort. The operations defined by the control statements have not been performed.

WER457A

VISUALEX NOT SPECIFIED OR INVALID EXPLANATION: The VISUALEX DD statement for export to Visual SyncSort is either missing or its data set has been incorrectly defined. The file must have physical sequential or extended sequential organization or be a member of a partitioned data set or PDSE. The record format must be undefined (RECFM=U) or unspecified.

WER458A

MAINTENANCE LEVEL INSUFFICIENT TO PROCESS VISUAL SYNCSORT SYSIN DATA SET EXPLANATION: The SYSIN data set created by Visual SyncSort cannot be processed by SyncSort. This is due to an insufficient level of maintenance on the SyncSort library. A newer level of SyncSort may be required to process the SYSIN data set.

WER459A

A VISUAL SYNCSORT APPLICATION MAY NOT text EXPLANATION: Only qualified SyncSort applications may be exported to Visual SyncSort. The reason this application is ineligible is supplied in the message text.

16.62

SyncSort for z/OS 1.2 Programmers Guide

WER460I

SORTIN DATA TRUNCATED DUE TO DCB BLKSIZE OVERRIDE EXPLANATION: An extended sequential data set used as input to a sort, merge or copy has had its DCB BLKSIZE overridden to a smaller value via a JCL specification. A physical block exceeding this overridden BLKSIZE specification was truncated to the smaller size during input processing. ACTION: Confirm that this truncation is desired. If not, remove the BLKSIZE specification from the JCL.

WER461A

SORTOUT/OUTFIL DATA SET CONTAINS NO DATA RECORDS EXPLANATION: If the NULLOUT=RC16 parameter is in effect and the SORTOUT data set had no records written to it during processing, WER461A will be posted. If one or more non-SORTOUT OUTFIL specifications had the NULLOFL=RC16 parameter in effect and they had no records written to them, the WER461A will be posted. The WER405I message, which details the records written to each OUTFIL, will provide information on the OUTFIL(s) that caused the message to be generated. Note that an OUTFIL, FILES=OUT, or FNAME SORTOUT is controlled by NULLOUT only, and not by NULLOFL.

WER461I

SORTOUT/OUTFIL DATA SET CONTAINS NO DATA RECORDS EXPLANATION: If the NULLOUT=RC4 parameter is in effect and the SORTOUT data set had no records written to it during processing, WER461I will be posted. If one or more non-SORTOUT OUTFIL specifications had the NULLOFL=RC4 parameter in effect and they had no records written to them, WER461I will be posted. The WER405I message, which details the records written to each OUTFIL, will provide information on the OUTFIL(s) that caused the message to be generated.

WER462A

OUTPUT LRECL DIFFERS FROM SORTOUT LRECL EXPLANATION: If the application is a sort, merge, or copy, the LRECL defined in the JCL for a non-OUTFIL SORTOUT differs from the SORTIN/SORTINnn LRECL or the internally processed record length when the SORTIN/SORTINnn LRECL is modified by features and the PAD and/or TRUNC parameters have been set to RC=16 to disallow this. In a BetterGener application, the LRECL defined in the JCL for SYSUT2 differs from the SYSUT1 LRECL or the internally modified record length when the SYSUT1 LRECL is modified by features and the SOPADGN and/or SOTRNGN installation options have been set to RC=16 to disallow this.

Chapter 16. Messages

16.63

ACTION: Remove the SORTOUT LRECL specification, allowing SyncSort to calculate the appropriate SORTOUT LRECL or modify the SyncSort control statements to build a record of the desired length as specified by the SORTOUT LRECL. WER462I OUTPUT LRECL DIFFERS FROM SORTOUT LRECL EXPLANATION: If the application is a sort, merge, or copy, the LRECL defined in the JCL for a non-OUTFIL SORTOUT differs from the SORTIN/SORTINnn LRECL or the internally processed record length when the SORTIN/SORTINnn LRECL is modified by features and the PAD and/or TRUNC parameters have been set to RC0 or RC4. In a BetterGener application, the LRECL defined in the JCL for SYSUT2 differs from the SYSUT1 LRECL or the internally modified record length when the SYSUT1 LRECL is modified by features and the SOPADGN and/or SOTRNGN installation options have been set to RC=0 or RC=4. Fixed-length records will be padded to the SORTOUT LRECL (SYSUT2 LRECL in a SYNCGENR application) when the SORTOUT LRECL is greater than the SORTIN or internally processed record length. Records will be truncated to the SORTOUT LRECL (SYSUT2 LRECL in a SYNCGENR application) when the SORTOUT LRECL is less than the SORTIN or internally processed record length. ACTION: Verify that the padding or truncation that will be performed is desired for this application. Refer to the provided WER108I and WER110I messages that detail the input and output record lengths. WER463A ddname IS A LINEAR VSAM DATA SET EXPLANATION: SyncSort does not support an input or output file that is a linear VSAM data set. WER464I INVALID SPANNED RECORD FOUND EXPLANATION: An invalid spanned record segment has been found while processing the input records in a sort or merge application, and VLTEST=(,{OFF,OFF4}) has been specified to produce a warning. When OFF4 has been specified, a return code of 4 will be issued if not overridden by a higher return code issued for another reason.

16.64

SyncSort for z/OS 1.2 Programmers Guide

WER467I

DB2 QUERY TRIAL MODE SUCCESSFULLY EXECUTED EXPLANATION: A report of the record layout produced by the DB2 query contained in the SORTDBIN data set has been successfully produced. No other processing has occurred.

WER468A

DB2 QUERY SUPPORT ERROR: text EXPLANATION: The DB2 query operation failed and the sort or copy application will not execute. The message text indicates the condition that caused the failure or the DB2 query requirement that was violated. MAXSORT MAY NOT BE SPECIFIED AN E15 EXIT MAY NOT BE SPECIFIED MERGE OPERATION MAY NOT BE SPECIFIED SKIPREC MAY NOT BE SPECIFIED SORTDBIN OPEN ERROR SORTDBIN CANNOT BE FOUND The DB2 parameter has been specified, but the required SORTDBIN DD has not been provided. NO SQL SELECT STATEMENT FOUND IN SORTDBIN INVALID COMMAND, ONLY SQL SELECT STATEMENT SUPPORTED Only a SELECT or $ELECT statement is valid in SORTDBIN. No other SQL operations are supported. QUERY STATEMENT TOO LONG (MAX 32765 BYTES) CANNOT CONNECT TO DB2 DB2 is not started or the subsystem name specified on the DB2 EXEC parameter is incorrect. CANNOT BIND PLAN The user ID from which the job was submitted has insufficient authority to bind the plan with the SyncSort module. Submit the application from an ID that is allowed the BIND privilege. CANNOT OPEN PLAN Insufficient resources were available for DB2 to process the open request. UNSUPPORTED DATA TYPE FOUND Long fields (LONG VARCHAR and LONG VARGRAPHIC) and large object fields (BLOB, CLOB, and DBCLOB) are not supported. UNKNOWN DATA TYPE FOUND SQL ERROR: SQLCODE=xxxx,SQLSTATE=yyyy Where xxxx is the SQLCODE and yyyy is the SQLSTATE returned. Refer to IBM publication DB2 Universal Database for OS/390 Messages and Codes (GC26-9011) for details on these return codes. DB2 MODULES ARE NOT LINKED The DB2 query facility of SyncSort for z/OS has not been installed during SyncSort installation. Contact your systems programmer for assistance.

Chapter 16. Messages

16.65

WER469A

BOTH JOINKEYS STATEMENTS MUST HAVE THE SAME NUMBER OF JOIN KEYS EXPLANATION: A join application requires two JOINKEYS statements that define the same number of JOINKEYS FIELDS, with each corresponding field having the same length and order specified.

WER470A

TWO JOINKEYS STATEMENTS ARE REQUIRED TO USE THE JOIN FEATURE EXPLANATION: A join application requires two JOINKEYS statements that define the same number of JOINKEYS FIELDS, with each corresponding field having the same length and order specified.

WER471A

A REFORMAT STATEMENT IS REQUIRED TO USE THE JOIN FEATURE EXPLANATION: A join application requires two JOINKEYS control statements and a REFORMAT control statement, unless a JOIN UNPAIRED control statement is present with the ONLY parameter specified.

WER472A

THE NUMBER OF JOIN FIELDS EXCEEDS THE MAXIMUM OF 64 EXPLANATION: The maximum number of JOINKEYS FIELDS that may be specified is 64.

WER473A

BOTH JOINKEYS STATEMENTS MUST HAVE CORRESPONDING KEY FIELDS OF EQUAL LENGTH EXPLANATION: A join application requires two JOINKEYS statements that define the same number of JOINKEYS FIELDS, with each corresponding field having the same length and order specified.

WER474A

TOTAL LENGTH OF JOIN KEYS IN JOINKEYS STATEMENTS EXCEEDS 4080 EXPLANATION: The maximum total length of all JOINKEYS FIELDS is 4080 bytes.

WER476A

FIRST 4 BYTES OF A VARIABLE-LENGTH REFORMAT DEFINITION MUST BE FROM A VL JOIN FILE EXPLANATION: When defining a variable-length record as the output of the join feature, the first four bytes defined must be for an RDW. This must be specified on the REFORMAT statement as

16.66

SyncSort for z/OS 1.2 Programmers Guide

FIELDS=(Fn:1,4,). This field may be taken from either of the SORTJNFn files if both are variable-length, but if only one file is variable-length, the field must come from the variable-length file. WER477A BOTH JOINKEYS STATEMENTS MUST HAVE CORRESPONDING KEY FIELDS WITH THE SAME ORDER EXPLANATION: A join application requires two JOINKEYS statements that define the same number of JOINKEYS FIELDS, with each corresponding field having the same length and order specified. WER478A A SORTJNF1 OR SORTJNF2 DD STATEMENT IS MISSING; BOTH ARE REQUIRED EXPLANATION: A join application requires the SORTJNF1 and SORTJNF2 DD definitions in the JCL. WER479A presence of

xxxxxxxx MAY NOT BE USED IN A JOIN APPLICATION EXPLANATION: A join application may not be specified with any of the following parameters: MAXSORT, PARASORT, PIPESORT, SKIPREC, MERGE function, user exits (except E35), CHECKPOINT, or DB2.

WER480A

A REFORMAT FIELD WITH ONLY A POSITION VALUE MUST REFERENCE A VARIABLE-LENGTH JOIN FILE EXPLANATION: A REFORMAT FIELD may only be specified as a position without a length value if it refers to a file defined as variablelength. This type of field definition may be specified once for each join file if they are both variable-length. These specifications must be the last fields defined on a REFORMAT statement.

WER481I

JOINKEYS REFORMAT RECORD LENGTH = nnnnn, TYPE = {F,V} EXPLANATION: nnnnn represents the length of the record produced by JOINKEYS REFORMAT processing. The TYPE represents the record format produced, either fixed (F) or variable (V). If you have variable-length records, nnnnn represents the maximum record length.

WER482I

JNFn STATISTICS EXPLANATION: JNFn is either JNF1 or JNF2 representing information on SORTJNF1 or SORTJNF2 processing that was performed during a join application. This message will be followed by other informational messages that apply to the SORT or COPY processing for that DD.

Chapter 16. Messages

16.67

WER483B

JNF1 or JNF2 processing information EXPLANATION: This message follows the WER482I message that defines which of the two join input files this message contains information about. The information details characteristics of the sort processing performed for SORTJNF1 or SORTJNF2 to prepare them for the join operation. Further information can be found in the explanations of the WER164B, WER410B, WER036B, WER158I, WER460I, WER464I, and WER162B messages.

WER484I

ddname: RCD IN=aaaaaaaa, OMITTED=bbbbbbbb, PAIRED=cccccccc, UNPAIRED=dddddddd EXPLANATION: The ddname will be either SORTJNF1 or SORTJNF2. aaaaaaaa represents the number of records read from the particular join input file. bbbbbbbb indicates the number of records deleted by the JOINKEYS INCLUDE/OMIT parameter. cccccccc is the number of records matched from this file during join processing. dddddddd is the number of records from this file that were unpaired during join processing.

WER485A

SORTJNFn OUT OF SEQUENCE, RECORD NUMBER=aaaaaaaa EXPLANATION: When the SORTED parameter is specified on the JOINKEYS statement, SyncSort will sequence check the input file according to its JOINKEYS fields. This message indicates that a sequence error was detected in either SORTJNF1 or SORTJNF2. aaaaaaaa is the record number within the file that caused the error. The record number is not provided if the INCLUDE/OMIT parameter of the JOINKEYS statement is specified.

WER486A

ERROR IN JNFn PROCESSING EXPLANATION: The n value is either 1 or 2 and indicates that an error has occurred while processing the SORTJNF1 or SORTJNF2 data sets. Examine the applications SYSOUT message data set for additional WERnnnA messages that will indicate the exact nature of the error.

WER487I

FILESIZE aaaaaaaa BYTES EXPLANATION: The aaaaaaaa represents the number of bytes of SORTJNF1 or SORTJNF2 input data sorted by SyncSort to prepare the file for join match field processing. This number reflects deletions made by JOINKEYS INCLUDE/OMIT processing. See the prior WER482I message to determine if FILESIZE is for SORTJNF1 or SORTJNF2.

16.68

SyncSort for z/OS 1.2 Programmers Guide

WER488A

JOIN CAPACITY EXCEEDED EXPLANATION: SyncSort is unable to complete the join application because of insufficient memory. This may be due to a user error in specifying the JOINKEYS fields, or the application may be very large relative to the amount of available memory. In order to join all records with equal JOINKEYS in SORTJNF1 with all records with matching JOINKEYS in SORTJNF2, SyncSort retains all the equally keyed SORTJNF2 records in memory to join with the next equally keyed record from SORTJNF1. The available amount of memory is determined by the available system resources and the region size and may not be sufficient if there are very many equally keyed records in SORTJNF2. ACTION: First examine the fields specified for the JOINKEYS FILE=F2 statement and correct any errors. If the fields were incorrectly specified, then many records may have been incorrectly determined to be equally keyed. If the JOINKEYS statement for F2 is correct, and if you believe that SORTJNF1 does not contain many equally keyed records that match the large number of equally keyed records in SORTJNF2, then this problem may be easily corrected by reversing the F1 and F2 definitions such that SORTJNF1 has many equally keyed records, but SORTJNF2 does not. To do this, reverse the DDNAMEs of the two files and change the JOINKEYS, REFORMAT, and JOIN UNPAIRED statements accordingly. If this does not solve the problem, then the total region size must be raised high enough to contain all of the SORTJNF2 equally keyed records. Contact SyncSort for z/OS Product Services for assistance, if necessary.

SyncSort Statistical Record Facility Messages


The following messages are not controlled by the MSG or FLAG PARM and will appear only on the console. WER500I SYNCSORT STATISTICS DATA SET NOW OVER xx PERCENT FULL EXPLANATION: xx percent of space currently allocated on the SyncSort Statistics data set has been used.

Chapter 16. Messages

16.69

WER501A

SYNCSORT STATISTICS DATA SET NOW FULL - NO RECORD WRITTEN EXPLANATION: The SyncSort Statistics data set did not have enough space for the SYNCSMF record.

PROC SYNCSORT Messages


WER700A PROC SYNCSORT UNSUPPORTED FUNCTION. {RETRY,NORETRY} IN EFFECT EXPLANATION: SyncSorts high performance technique could not be used during this invocation by PROC SYNCSORT - An Accelerator for SAS Sorting. This may be due to a small region size or the generation of an unsupported SyncSort statement syntax. If the RETRY option of PROC SYNCSORT is in effect, SyncSort for z/OS will be reinvoked using a less efficient E15-E35 interface. If the RETRY option is not in effect, the PROC SYNCSORT execution will be terminated. WER744A CONFLICT BETWEEN SYNCSORT AND PROC SYNCSORT MAINTENANCE LEVELS, VERIFY LIBRARIES EXPLANATION: Maintenance has been applied to either PROC SYNCSORT or SyncSort for z/OS, but not to both when maintenance to both is required. ACTION: Check the libraries containing PROC SYNCSORT and SyncSort for z/OS and apply the required level of maintenance to each. WER775A SAS I/O ERROR OCCURRED. CHECK SAS MESSAGE LOG DATASET EXPLANATION: An I/O error occurred when a SAS routine attempted to access or update a SAS data set. A message indicating the actual nature of the problem should appear on the SAS message LOG data set. WER776A BLDL FAILURE FOR DDNAME SASLIB. RAISE REGION OR CHECK SASLIB ACCESS EXPLANATION: When attempting to perform a BLDL for the library identified by the SASLIB DD statement, an error occurred. The error is due either to insufficient virtual storage or a permanent I/O error on the library.

16.70

SyncSort for z/OS 1.2 Programmers Guide

WER777A

ERROR LOADING PROC SYNCSORT MODULE. CHECK PROC SYNCSORT INSTALL EXPLANATION: The PROC SYNCSORT module could not be found in any of the libraries on the normal z/OS search chain or an error occurred while loading the module.

WER778A

UNEQUAL MAINTENANCE APPLIED TO PROC SYNCSORT AND SYNCSORT LIBRARIES. DATA=hexdata EXPLANATION: The maintenance level of the PROC SYNCSORT product is in conflict with that of the SyncSort for z/OS product due to the incomplete application of one or more maintenance levels. The hexadecimal data, if printed, indicates which maintenance fixes were incompletely applied.

WER779I

THE PERFORMANCE OF THIS SORT COULD BE SIGNIFICANTLY IMPROVED THROUGH THE USE OF THE PROC SYNCSORT PRODUCT EXPLANATION: PROC SYNCSORT - An Accelerator for SAS Sorting is a high performance replacement for the SAS-provided procedure PROC SORT. When SyncSort is invoked with the PROC SYNCSORT product instead of through the interface supplied by SAS, significant performance improvements result. For more information, call SyncSort for z/OS Product Services.

License Key Messages


The following are the messages directly related to the use of a SyncSort for z/OS license key. WER900A SYNCSORT r.r.n.n IS NOT LICENSED FOR SERIAL sssss, TYPE mmmm mmm, [LPAR nn,] MSU ccccc. or SYNCSORT r.r.n.n IS NOT LICENSED FOR SERIAL sssss, TYPE mmmm, [LPAR nn,] VERSION CODE vv. EXPLANATION: r.r is the SyncSort release number, and n.n is the TPF maintenance level. No valid license key for use on the specified machine was found, and the grace period for this error, noted by the WER903I warning message, has expired. A key must contain the correct information for both the serial number and the full model number. License keys are specified either in the KEY parameter of the SYNCMAC installation options macro, or included in a data set whose name is specified in the KEYDSN parameter of SYNCMAC.

Chapter 16. Messages

16.71

ACTION: Execute the SYNCLIST program on the system where this message is occurring. Ensure that either the SYNCMAC KEY parameter or the data set named in the KEYDSN parameter has provided a valid key for this machine. If you require further assistance, contact SyncSort for z/OS Product Services with the SYNCLIST output available for reference. WER901I **WARNING** SYNCSORT r.r.n.n WILL EXPIRE IN nnn DAYS EXPLANATION: r.r is the SyncSort release number, and n.n is the TPF maintenance level. The provided license key for this machine is only valid for the next nnn days. After that time, WER902A will be issued, and SyncSort will not execute. ACTION: Contact the systems programmer in charge of SyncSort maintenance, or execute the SYNCLIST program on the system where this message is occurring and contact SyncSort for z/OS Product Services. WER902A SYNCSORT r.r.n.n HAS EXPIRED EXPLANATION: r.r is the SyncSort release number, and n.n is the TPF maintenance level. The provided license key for this machine is no longer valid because the expiration date has passed. SyncSort will no longer execute. ACTION: Contact the systems programmer in charge of SyncSort maintenance, or execute the SYNCLIST program on the system where this message is occurring and contact SyncSort for z/OS Product Services. WER903I SYNCSORT r.r.n.n IS NOT LICENSED FOR SERIAL sssss, TYPE mmmm mmm, [LPAR nn,] MSU ccccc. or SYNCSORT r.r.n.n IS NOT LICENSED FOR SERIAL sssss, TYPE mmmm, [LPAR nn,] VERSION CODE vv. SYNCSORT WILL STOP WORKING IN nnn DAYS UNLESS A VALID KEY IS INSTALLED. EXPLANATION: r.r is the SyncSort release number, and n.n is the TPF maintenance level. No valid license key for use on the specified machine was found. License keys are specified in the KEY parameter of the SYNCMAC installation options macro, or included in a data set whose name is specified in the KEYDSN parameter of SYNCMAC. SyncSort will allow sort processing to continue by issuing WER903I during a grace period after this error is first encountered. This will provide sufficient time to correct the problem by installing a valid key for

16.72

SyncSort for z/OS 1.2 Programmers Guide

this machine. If the grace period ends before a valid key is made available, WER900A will be issued and sort processing will terminate. ACTION: Execute the SYNCLIST program on the system where this message is occurring. Ensure that either the SYNCMAC KEY parameter or the data set named in the KEYDSN parameter has provided a valid key for this machine. If you require further assistance, contact SyncSort for z/OS Product Services with the SYNCLIST output available for reference. WER904I SYNCSORT r.r.n.n KEYUPDATE SUCCESSFUL; xxxxxxxxxxxxxxxx SELECTED EXPLANATION: r.r is the SyncSort release number, and n.n is the TPF maintenance level. The KEYUPDATE parameter was specified, and SyncSort has successfully obtained a valid license key denoted by xxxxxxxxxxxxxxxx from SyncSorts key data set. The name of the data set was specified in the KEYDSN parameter of the SYNCMAC installation options macro. WER905A SYNCSORT r.r.n.n KEYUPDATE FAILURE: reason EXPLANATION: r.r is the SyncSort release number, and n.n is the TPF maintenance level. The KEYUPDATE parameter was specified, but SyncSort was unable to obtain a valid license key from SyncSorts key data set due to the specified reason. Possible reasons for this failure are: 1. The KEYDSN parameter of SYNCMAC was not specified when SyncSort was installed. KEYDSN, and not the KEY parameter, must be specified with the name of SyncSorts key data set when using the KEYUPDATE facility. 2. SyncSort was unable to dynamically allocate and/or read SyncSort's key data set. This can happen if you were editing the data set at the time of the KEYUPDATE run, or if the data set was not allocated as a fixed-length 80-byte file. 3. No valid license key was found in SyncSort's key data set. 4. The SyncSort SVC was not available. SyncSort requires use of its SVC to perform the update. ACTION: Ensure that the KEYDSN parameter has been correctly specified and that the data set is accessible and contains a valid license key. Also verify that the SyncSort SVC has been properly installed. If you require further assistance, execute the SYNCLIST program on the sys-

Chapter 16. Messages

16.73

tem where this message is occurring and contact SyncSort for z/OS Product Services with the SYNCLIST output available for reference. WER906I INVALID KEY DATA SET RECORD: invalid record text EXPLANATION: One or more invalid records were found in the license key data set when performing KEYUPDATE. The first invalid record is displayed in the message text. Only comment statements, key statements and valid PARMS statements are permitted. All invalid statements are ignored. ACTION: Correct any errors in the key data set record that was displayed in the message text and rerun the KEYUPDATE application. WER907I SYNCSORT EXPIRING LICENSE KEY WARNING MESSAGE {ENABLED,DISABLED} or SYNCSORT INVALID LICENSE KEY WARNING MESSAGE {ENABLED,DISABLED} EXPLANATION: These KEYUPDATE messages document whether SyncSort may issue certain license key warning messages. The default is for SyncSort to issue either the WER901I expiring license key warning message or the WER903I invalid license key warning message when applicable. During KEYUPDATE, a PARMS statement read from the key data set can disable the issuance of either of these messages. The WER907I message is intended to alert you that these warning messages may no longer be posted, though the warning period countdowns will continue. During the last seven days before the warning period ends, SyncSort will issue the warning messages regardless of whether they have been disabled. This is done to try to prevent termination of all SyncSort applications with either WER902A or WER900A. ACTION: No action is required if both of these warning messages are enabled and you have a valid license key that is not expiring. If you do not have a valid key or if your key is expiring, call SyncSort for z/OS Product Services as soon as possible to obtain a new license key and rerun the KEYUPDATE procedure using the new key. If any of the messages had been disabled, either remove the PARMS statement or set the warning message parameters to ON to re-enable the issuance of license key warning messages.

16.74

SyncSort for z/OS 1.2 Programmers Guide

Troubleshooting Abends
Troubleshooting with WER999A UNSUCCESSFUL SORT
WER999A indicates that an error condition occurred, preventing the successful completion of the sort. This message does not necessarily mean that SyncSort was responsible for the error. If, for example, the error is in the COBOL Input or Output Procedure of an invoked sort, WER999A will appear. WER999A indicates that SyncSort got control after the error, printing this SyncSort message. The documentation accompanying WER999A varies with the error involved. It may consist of a standard system dump (SYSUDUMP or SYSABEND) and/or a SyncSort-generated SNAP dump. The SyncSort SNAP is formatted very much like a SYSUDUMP. In debugging the SNAP, care must be taken to avoid reliance on the PSW AT ENTRY TO SNAP and the general registers. (A SNAP dump produced through the SyncSort DEBUG PARM or with a W-abend (i.e., WER999A UNSUCCESSFUL SORT xxxW) is only useful to a sort analyst at SyncSort for z/OS Product Services. See What to Do Before Calling SyncSort for z/OS Product Services.)

SyncSort Internal Abend


A W-type abend code indicates that program termination was forced by an error condition internally detected by SyncSort; the problem cannot be resolved by the user. See What to Do Before Calling SyncSort for z/OS Product Services, below.

User-Issued Abend
If any of the following abend codes appear in WER999A, it may indicate a SyncSort error (in which case, see What to Do Before Calling z/OS Product Services). These are the only U-type abend codes that SyncSort issues; any U-type abend code which is not on this list indicates an error in a user-written exit routine or invoking program. Note that WER999A gives the abend code in hexadecimal.

User Abend 4093


User abend 4093 (RC=1C) is related to LOCALE processing. This abend is issued from the LE/370 environment when the REGION is not large enough. Increase the REGION by 1 megabyte and resubmit the application. User-Type Abend Codes Issued by SyncSort Decimal Hexadecimal Decimal Hexadecimal

Table 46. (Page 1 of 3) User Type Abend Codes

Chapter 16. Messages

16.75

User-Type Abend Codes Issued by SyncSort 10 16 * 69 100 101 200 300 400 936 999 ** 1024 *** 1025 1026 1027 1028 1030 1031 1032 1050 1051 1052 1053 1054 1060 1061 1070 1071 1072 1073 1074 1075 1076 1077 1078 1079 A 10 * 45 64 65 C8 12C 190 3A8 3E7 ** 400 *** 401 402 403 404 406 407 408 41A 41B 41C 41D 41E 424 425 42E 42F 430 431 432 433 434 435 436 437 1086 1087 1088 1102 1103 1104 1107 1108 1110 1111 1112 1115 1116 1117 1118 1119 1120 1121 1122 1123 1124 1125 1126 1127 1128 1129 1131 1188 1189 1190 1191 1192 1193 1194 1195 43E 43F 440 44E 44F 450 453 454 456 457 458 45B 45C 45D 45E 45F 460 461 462 463 464 465 466 467 468 469 46B 4A4 4A5 4A6 4A7 4A8 4A9 4AA 4AB

Table 46. (Page 2 of 3) User Type Abend Codes

16.76

SyncSort for z/OS 1.2 Programmers Guide

User-Type Abend Codes Issued by SyncSort Decimal 1197 1198 1812 1813 1814 1815 1816 1817 1818 1819 1820 1837 1838 1981 Hexadecimal 4AD 4AE 714 715 716 717 718 719 71A 71B 71C 72D 72E 7BD Decimal 1985 1986 1987 1990 1991 1992 1993 1994 1997 1998 2048 2049 2050 2081 Hexadecimal 7C1 7C2 7C3 7C6 7C7 7C8 7C9 7CA 7CD 7CE 800 801 802 821

* The RC16=ABE option is specified and there has been a critical error. ** The IOERR=ABE option is specified and there has been an I/O error. *** This is most commonly caused by the release of SyncSorts SVC not matching the release of the SyncSort module. Table 46. (Page 3 of 3) User Type Abend Codes

What to Do Before Calling SyncSort for z/OS Product Services


All pertinent information (listings, dumps, etc.) should be available for easy reference when calling SyncSort for z/OS Product Services. For error conditions producing the WER999A message, the system dump and/or SyncSort SNAP dump will prove helpful to a SyncSort analyst. For other conditions cited with an A class message (e.g., WER039A INSUFFICIENT VIRTUAL STORAGE), additional diagnostic information may be required a diagnostic SNAP dump can be produced by passing the DEBUG PARM in the $ORTPARM DD statement or (for a JCL sort) in the //EXEC statement. When using DEBUG, supply a SPYSET or SYSUDUMP DD statement to define an appropriate SYSOUT data set for the dump. In the United States and Canada, call SyncSort for z/OS Product Services directly at (201) 930-8260. The address is: Syncsort Incorporated SyncSort for z/OS Product Services 50 Tice Boulevard Woodcliff Lake, New Jersey 07677 FAX: (201) 930-8284 E-mail: [email protected]

Chapter 16. Messages

16.77

16.78

SyncSort for z/OS 1.2 Programmers Guide

Index

Symbols $ORTPARM Statement 4.1, 4.124.15, 5.1, 6.2, 7.9, 7.30, 12.5 $ORTPARM, for Century Window 4.14 $ORTPARM, with CENTWIN 4.14 &DATE 2.118 &DATENS=(xyz) 2.78, 2.84, 2.118 &DATEx 2.23, 2.312.32 &DATEx(c) 2.23, 2.312.32 &DATExP 2.23, 2.312.32 &TIME=(hp) 2.118 &TIMENS=(tt) 2.79, 2.85 A AC Format 2.22, 2.32, 2.47, 2.114, 2.117, 2.146 ACS 2.161, 5.13 ALTSEQ Control Statement 2.162.17, 6.96.10, 7.57 AMODE 6.13 AND Operator 2.24, 3.3 ANSI Control Characters 2.922.93 AQ Format 2.16, 2.22, 2.32, 2.47, 2.114, 2.117, 2.146 ASL Format 2.22, 2.32, 2.47, 2.114, 2.117, 2.146 Assembler Programs 1.1 Invoking SyncSort from 6.1, 6.19

AST Format 2.22, 2.32, 2.47, 2.114, 2.117, 2.146 ATTACH Macro 6.2, 7.8, 7.29 Authorization Messages 16.71 Averages, Example 3.56 AVG 2.86 B B Messages See BMSG Option BALANCE Option 5.3, 13.4 BALN Option 5.2, 6.7, 6.10, 12.312.5 BatchPipes/MVS 2.73, 4.5, 4.74.8 BI Format 2.22, 2.32, 2.47, 2.114, 2.117, 2.146 Binary Zeros, Insertion of 2.992.116, 3.283.29 Bit Level Comparison 2.23 Bit Level Logic 2.232.24, 2.342.36 BKPTDSN Option (MAXSORT) 5.1, 9.10 BLKSIZE Parameter 4.4, 5.5, 5.24, 5.275.28 Block Size 5.275.28 BMSG Option 5.3, 5.7 BSAM 4.5, 4.8 BUFOFF Parameter 4.4 C C E15 7.197.27
Index

I.1

C E35 7.437.51 C Exits 7.197.27, 7.437.51 C Programs 1.1 Century Window Processing ??2.502.51, 2.1122.114, 2.133, 2.136, 2.1492.159 Century Window, with $ORTPARM 4.14 CENTWIN Option ??2.502.51, 2.1492.159, 5.3, 5.75.9 CENTWIN Processing, with OUTREC 2.133, 2.136 CENTWIN, with $ORTPARM 4.14 CH Format 2.22, 2.32, 2.47, 2.114, 2.117, 2.146 CHANGE 2.125 Channel Separation 13.14 Checkpoint-Restart 4.15, 13.913.13 Automatic 13.1113.12 Deferred 13.1213.13 CKPT/CHKPT Parameter (MERGE) 2.58 CKPT/CHKPT Parameter (SORT) 2.160 CLO Format 2.22, 2.32, 2.47, 2.114, 2.117, 2.146 CMP Option 5.3, 13.3 CMP=CLC 2.50, 5.3, 13.3 CMP=CPD 2.50, 5.3, 13.3 COBOL E15 5.14, 7.97.19 DATA DIVISION 7.12 ENVIRONMENT DIVISION 7.12 EXIT-STATUS Codes 7.13 Fixed-Length Records 7.10, 7.157.16 IDENTIFICATION DIVISION 7.12 LINKAGE SECTION 7.107.12 PROCEDURE DIVISION 7.13 RETURN-CODE Codes 7.137.14 Variable-Length Records 7.117.12, 7.177.19 WORKING-STORAGE SECTION 7.12 COBOL E35 5.14, 7.307.42 DATA DIVISION 7.34 ENVIRONMENT DIVISION 7.34 EXIT-STATUS Codes 7.35 Fixed-Length Records 7.317.32, 7.377.39 IDENTIFICATION DIVISION 7.34 LINKAGE SECTION 7.317.34 PROCEDURE DIVISION 7.34 RETURN CODE Codes 7.357.36 Variable-Length Records 7.337.34, 7.407.42 WORKING STORAGE SECTION 7.34 COBOL Exits 7.5, 7.97.19, 7.307.42 COBOL Programs 1.1, 6.1, 13.2 COBOL, and Century Window 4.14

CODE Parameter (ALTSEQ) 2.16 Coding Conventions 4.34.4 Collating Sequence 2.162.17, 2.47, 7.57 Combining Records in a File 3.11 COMMAREA Option 5.3, 5.10, 7.4 Communication Area 5.10 Communication Area for Exits 7.4 Comparing Fields 2.202.37, 2.149, 3.33.11 Bit Level Criteria 2.232.24 Constants 2.22 Field to Constant Comparison 2.29 PD and ZD Field Comparison 2.50, 2.149 Rules for Specifying Fields 2.50 Concatenating Input Data Sets 4.6 COND Parameter (INCLUDE/OMIT) 2.202.37 Contacting Syncsort 16.77 Control Statement Syntax 2.112.14 Control Statements 2.12.167 ALTSEQ 2.162.17, 6.96.10, 7.57 Coding in Invoked Programs 6.2 Comments in 2.13 Continuation of 2.132.14 DEBUG 6.9 Defaults 2.2 END 2.18, 6.3, 12.6 for MAXSORT 9.10 for Tape Sort 12.6 INCLUDE/OMIT 2.192.37, 3.33.6, 5.16, 5.29, 6.9, 13.2 INREC 2.382.39, 3.63.11, 6.9, 13.213.3 JOIN 2.40 JOINKEYS 2.42 Labels in 2.14 MERGE 2.38, 2.462.60, 5.13, 5.16, 5.29, 6.2, 6.8, 7.567.57 MODS 2.612.64, 5.14, 6.3, 6.5, 6.9, 12.6 Notational Conventions 2.14 OMIT 2.65 OUTFIL 2.38, 2.662.96, 3.363.64, 6.2, 6.96.10, 13.2 OUTREC 2.38, 2.972.136, 3.24, 6.96.10, 13.213.3 Performance Considerations 13.213.3 Processing Sequence 2.92.11 RECORD 2.1372.140, 6.3, 12.6 REFORMAT 2.141 Requirements for Disk Sort 2.8 Requirements for MAXSORT 2.8

I.2

SyncSort for z/OS 1.2 Programmers Guide

Requirements for Tape Sort 2.8 Rules for Specifying 2.112.14 See $ORTPARM Statement See Job Control Language See SYSIN Statement SORT 2.38, 2.144, 5.13, 5.16, 5.29, 6.2, 7.52, 7.567.57, 12.6 Specifying Field Formats in 2.12 Specifying Field Lengths in 2.12 Specifying Field Positions in 2.12 Specifying Parameters in 2.112.12 SUM 2.38, 2.1642.167, 3.11, 5.14, 5.16, 6.9, 7.27, 13.2 Summary of Functions 2.1 Summary of Parameters and Defaults 2.2 Summary of the Chapter 1.7 Use in Invoked Applications 6.36.4 CONVERT Parameter (OUTFIL) 2.75 CONVERT Parameter (OUTREC) 2.128 Converting Data 2.102, 2.104, 2.106, 2.1082.109, 2.1142.119, 3.293.36, 5.8 Format 2.1022.104 Converting Fixed-Length Records to VariableLength Records 2.75 Converting SMF Formats 2.114 Converting Variable-Length Records 2.75, 2.99, 2.1283.36 Converting Year Data 2.1122.114 Copy Creating Input Data Sets for 4.5 Flow of 8.18.9 Copying 1.2 Phases of 1.3 CORE Option 5.3, 5.11, 13.413.6 COUNT 2.87 COUNT15 2.88 CPU Option 5.3, 5.7, 13.4 CRCX Option 6.7, 6.10 CSF Format 2.22, 2.32, 2.114, 2.117 CSL Format 2.22, 2.32, 2.47, 2.114, 2.117, 2.146 CST Format 2.22, 2.32, 2.47, 2.114, 2.117, 2.146 CTO Format 2.22, 2.32, 2.47, 2.49, 2.114, 2.117, 2.146, 2.148 Cultural Environment 1.5, 2.46, 2.144 D DASD Data Set 4.4

Data Set Placement 13.1313.14 Data Utility 3.13.64 Duplicate Records 3.113.13 Examples, Index to 3.2 Features of 1.3, 3.1 Input Record Selection 3.23.11 Input Records, Selection of Relevant Fields 3.63.11 Output Files, Multiple 3.623.64 Output Records Converting Data 3.323.34 Converting Data to Hexadecimal Format 3.313.32 Converting Data to Readable Form 3.293.31 Editing Data 3.323.34 Editing of 3.233.36 Formatting Data Fields 3.343.36 Inserting Binary Zeros 2.992.116, 3.283.29 Inserting Blanks 3.263.27 Reordering Field Positions 3.243.27 Output Reports Counting Data Records 3.583.62 Headers and Trailers for 3.413.50 Sectioning of 3.393.41 Totaling and Subtotaling Data 3.503.55 Sample Applications, Summarized 3.2 Summary of the Chapter 1.7 DATE (&DATE) 2.78, 2.83, 2.117 DB2 Query Support 11.1 DCB Information 2.137 DCB Parameter 4.4, 5.5, 5.24, 5.27 DD Statements 4.44.17, 9.49.10, 10.3, 12.312.5 $ORTPARM Statement 4.124.15, 6.2, 12.5 Coding Conventions 4.34.4 JOBLIB Statement 4.4 Parameters AMP 4.4 BLKSIZE 4.4 BUFND 4.4 BUFNI 4.4 BUFOFF 4.4 BUFSP 4.4 DCB 4.4 DISP 4.4 DSNAME/DSN 4.4 LABEL 4.4 LRECL 4.4 OPTCD 4.4 RECFM 4.4 SPACE 4.4 UNIT 4.4
Index

I.3

VOLUME/VOL 4.4 See Exit Programs, Link-editing SORTBKPT Statement 9.69.7 SORTCKPT Statement 4.15, 13.2 SORTIN Statement 4.54.7, 6.2 SORTINn Statement 4.7 SORTINnn Statement 6.2 SORTJNF1 Statement 4.8 SORTJNF2 Statement 4.8 SORTLIB Statement 6.2, 12.3 SORTMODS Statement 4.15 SORTOFx Statement 4.8, 6.2 SORTOFxx Statement 4.8, 6.2 SORTOU00 Statement 9.79.9 SORTOUT Statement 4.8, 6.2 SORTPARn Statement 10.510.7 SORTWKnn Statement 4.104.11, 6.2, 12.412.5 SORTXSUM 4.8 STEPLIB Statement 4.4 Summarized for Invoked Sort/Merge 6.16.2 SYSIN Statement 4.11 SYSLIN Statement 4.15 SYSLMOD Statement 4.16 SYSOUT Statement 4.4, 6.2 SYSPRINT Statement 4.16 SYSUT1 Statement 4.16 ddname 4.1, 9.5, 10.3, 11.3, 12.3 DEBUG Control Statement 6.9 DEBUG Option 5.3, 5.12 Defining Output Data Sets See SORTOUT Files See SORTOUT Statement Defining Work Areas See SORTWKnn Statement Deleting Trailing Bytes From Fixed-Length Records 2.76 Device Separation 13.14 DIAG Option 5.3, 5.12, 6.7, 6.10 Disk Sort 4.1, 13.8 Control Statements 2.12.167 DD Statements for 4.14.16 Device Types 4.10 EXEC Statement for 4.2 PARM Options 12.1 PARMS Options 5.1 Performance Considerations 13.1 DISP Parameter 4.4, 5.27 DSN Parameter

See DSNAME Parameter DSNAME Parameter 4.4 DT1 2.114 DT2 2.114 DT3 2.114 Duplicate Records 3.113.13 DYNALLOC Option 4.1, 5.3, 5.125.13 DYNALLOC Parameter (SORT) 2.1602.161 DYNATAPE Option (MAXSORT) 4.1, 5.1, 9.10, 9.149.16 E E10 2.63 E11 2.63, 7.5 E14 4.11, 5.16, 7.67.7, 9.13 E15 2.63, 5.16, 7.67.9, 7.58, 9.13, 12.6, 12.9, 14.4 See COBOL E15 E15 Option 5.3, 5.14, 7.9 E15=COB 5.3 E16 4.11, 7.51, 9.13 E17 7.52 E18 7.527.55 E20 2.63 E21 2.63, 7.5 E25 7.6, 7.277.28, 9.13 E27 7.52 E30 2.63 E31 2.63, 7.5 E32 2.59, 6.2, 7.5, 12.6 E35 4.2, 7.6, 7.287.30, 7.58, 9.13, 12.6, 12.9 See COBOL E35 E35 Option 5.3, 5.14 E35=COB 5.3 E37 7.52 E38 7.527.55 E39 7.52, 7.557.56 E61 2.63, 7.567.58, 9.13 EDIT 2.87 Edit Patterns 2.1192.125, 3.34 EDIT Subparameter 2.119 Editing Data 2.1102.128, 3.233.36 Editing Masks 2.87, 2.1212.125 ELAP Option 5.35.4, 5.7, 5.14, 13.4 END Control Statement 2.18, 12.6 ENDREC Parameter (OUTFIL) 2.71 Equal-keyed Records 2.59, 2.161, 2.164, 5.14 EQUALS Option 5.4, 5.14, 13.3

I.4

SyncSort for z/OS 1.2 Programmers Guide

EQUALS/NOEQUALS Parameter (MERGE) 2.59 EQUALS/NOEQUALS Parameter (SORT) 2.161 Esoteric Names 10.7 EXEC Statement 4.2, 9.4, 10.2, 11.2, 12.2 for Disk Sort 4.2 for MAXSORT 4.3, 9.4 for PARASORT 10.2, 11.2 for Tape Sort 4.3, 12.212.3 Exit Conventions 7.3 Exit Programs 2.612.64, 7.17.60 Acting on Insufficient Storage 7.51 Adding Records 7.287.30 Analyzing Sort Input File 7.77.9 Changing Records 7.67.7, 7.277.30 Checking Labels 7.527.55 Closing Exit Data Sets 7.52 Communication Area 7.4 Creating Input Records 7.57.9 Creating Sort Input File 7.77.9 Definition of 7.1 Deleting Records 7.67.7, 7.277.30 End-of-File Routines 7.527.55 for Invoked Merge 7.5 Identified in MODS Control Statement 7.3 Link-editing 7.3 Link-editing at Execution Time DD Statements Required for 4.154.16 Loading into Main Storage 7.3 MAXSORT 9.13 Modifying Collating Sequence 7.567.58 Phases 7.17.2 Preparing for Other Exit Programs 7.5 Processing Read Errors 7.527.55 Processing Write Errors 7.527.55 Program Labels 7.1 Register Conventions 7.4 Revising Sort Input File 7.77.9 Summarizing Records 7.67.7, 7.277.28 Summary of Tasks Performed 7.2 Summary of the Chapter 1.8 VSAM Processing 7.52, 7.55 with Disk Sort 2.63 with MAXSORT 2.63, 9.13 with PARASORT 2.63 with Tape Sort 2.63, 12.6, 12.9 Exit Programs, Link-editing 4.16 Exit-Name Parameter (MODS) 2.612.63 EXTCOUNT 5.4, 5.15 EXTCOUNT Option 5.3

F F1 Parameter (JOIN) 2.40 F2 Parameter (JOIN) 2.40 FI Format 2.22, 2.32, 2.47, 2.114, 2.117, 2.146 Field Format Codes 2.472.50, 2.1452.148 AC 2.22, 2.32, 2.47, 2.114, 2.117, 2.146 AQ 2.16, 2.22, 2.32, 2.47, 2.114, 2.117, 2.146 ASL 2.22, 2.32, 2.47, 2.114, 2.117, 2.146 AST 2.22, 2.32, 2.47, 2.114, 2.117, 2.146 BI 2.22, 2.32, 2.47, 2.114, 2.117, 2.146 CH 2.22, 2.32, 2.47, 2.114, 2.117, 2.146 CLO 2.22, 2.32, 2.47, 2.114, 2.117, 2.146 CSF 2.22, 2.32, 2.114, 2.117 CSL 2.22, 2.32, 2.47, 2.114, 2.117, 2.146 CST 2.22, 2.32, 2.47, 2.114, 2.117, 2.146 CTO 2.22, 2.32, 2.47, 2.49, 2.114, 2.117, 2.146, 2.148 FI 2.22, 2.32, 2.47, 2.114, 2.117, 2.146 FL 2.47, 2.146 FS 2.22, 2.32, 2.114, 2.117 List of Valid Formats 2.472.50, 2.1462.148 LS 2.22, 2.32, 2.114, 2.117 OL 2.22, 2.32, 2.47, 2.114, 2.117, 2.146 OT 2.22, 2.32, 2.49, 2.114, 2.117, 2.146, 2.148 P2ID 2.113 P2IP 2.113 PD 2.22, 2.32, 2.47, 2.114, 2.117, 2.146 PD0 2.22, 2.32, 2.48, 2.54, 2.114, 2.117, 2.147, 2.153 TS 2.22, 2.32, 2.47, 2.114, 2.117, 2.146 Y2B 2.22, 2.32, 2.48, 2.51, 2.1132.114, 2.117, 2.147, 2.149 Y2C 2.22, 2.32, 2.48, 2.52, 2.1132.114, 2.117, 2.147, 2.150 Y2D 2.22, 2.32, 2.49, 2.52, 2.1132.114, 2.117, 2.147, 2.150 Y2P 2.22, 2.32, 2.49, 2.52, 2.1132.114, 2.117, 2.147, 2.151 Y2S 2.22, 2.32, 2.49, 2.53, 2.1132.114, 2.117, 2.147, 2.151 Y2Z 2.22, 2.32, 2.49, 2.52, 2.1132.114, 2.117, 2.148, 2.150 ZD 2.22, 2.32, 2.49, 2.114, 2.117, 2.146, 2.148 Fields 2.972.136 Binary 2.19, 2.232.24, 2.145 Bit Level Comparison 2.23 Comparison of 2.202.37, 2.149, 3.33.11 Constants 2.22
Index

I.5

Format 2.45, 2.472.110, 2.1452.148 Insertion of Binary Zeros 3.283.29 Insertion of Blanks 3.263.27 Length 2.145 Position 2.104, 2.106, 2.1082.109, 2.114, 2.145, 5.8 Reordering 3.243.27 Rules for Specifying 2.50, 2.148 Selection of 3.63.11 Specifying Format 2.12 Specifying Length 2.12, 3.6 Specifying Position 2.12, 3.6 Substring Comparison 2.33 FIELDS Parameter (INREC) 2.38 FIELDS Parameter (JOINKEYS) 2.43 FIELDS Parameter (MERGE) 2.462.51 FIELDS Parameter (OUTREC) 2.992.128 FIELDS Parameter (SORT) 2.1442.159 FIELDS Parameter (SUM) 2.1642.165 FIELDS Subparameters 2.100 Operator 2.102 FIELDS=COPY 2.50, 2.59, 2.159 FIELDS=NONE 2.164 FILE Parameter (JOINKEYS) 2.43 File Size See FILSZ Option FILES Parameter (MERGE) 2.59 FILES Parameter (OUTFIL) 2.69, 3.623.64 FILL Parameter (REFORMAT) 2.142 FILSZ Option 5.4, 5.155.16 FILSZ Parameter (SORT) 2.162 Fixed-Length Records 2.12, 2.50, 2.99, 2.128, 2.137, 7.10, 7.157.16 Maximum Length 4.5 FL Format 2.47, 2.146 FLAG Option 5.4, 5.16, 6.10 Flow of the Sort 8.18.9 FNAMES Parameter (OUTFIL) 2.70 FORMAT 2.21, 2.452.47, 2.1442.145, 2.1632.164, 2.167 SORT 2.163 FORTRAN Programs 1.1, 6.1 FS Format 2.22, 2.32, 2.114, 2.117 FTOV Parameter (OUTFIL) 2.75 Full-date formats 2.54, 2.154

G Generating Run-Time Constants GETMAIN 2.62, 6.3 Group, OUTFIL 2.692.70 H HBSI Option 4.5, 5.4, 5.16 HBSO Option 4.10, 5.4, 5.17 HEADER1 / HEADER2 Parameter (OUTFIL) 2.762.80, 3.41 HFS 4.5, 4.74.8 Hiperbatch 5.17 Hiperbatch Processing 5.165.17 HISTOGRM 2.1392.140, 5.18, 7.7, 14.114.13 Control Parameters 14.214.4 Executing through E15 14.414.6 Job Control Language 14.4 Messages 14.914.13 Output Samples 14.714.8 Summary of the Chapter 1.8 I INCLUDE/OMIT Control Statement 2.192.37, 3.33.6, 5.16, 5.29, 6.9, 13.2 INCLUDE/OMIT Parameter (JOINKEYS) 2.45 INCLUDE/OMIT Parameter (OUTFIL) 2.702.71 Incore Sort 2.59, 2.160, 2.166, 8.1, 13.6 Input Data Sets Concatenation of 4.6 Input Records Selection of 3.23.11 INREC Control Statement 2.382.39, 3.63.11, 6.9, 13.213.3 Installation Guide 1.9 Installation Options Precedence Rules 5.2 Intermediate Storage 4.104.11, 12.4 Invoking SyncSort from a Program 6.16.19 Assembler Programs 6.2 DD Statements 6.1 Macro Instructions for Invoking SyncSort from an Assembler Program ATTACH 6.2 LINK 6.2 LOAD 6.2 XCTL 6.2 2.116

I.6

SyncSort for z/OS 1.2 Programmers Guide

MAXSORT 9.13 Performance Considerations 6.1 Restrictions on Control Statements Tape Sort 12.912.11 IO Option 5.35.4, 5.7, 5.17, 13.4 IOERR Option 5.4, 5.17, 6.10 IOERR=ABE 5.4 J

6.36.4

LINES Parameter (OUTFIL) 2.912.93 LINK Macro 6.2, 7.8, 7.29 LIST Option 5.4, 5.18, 6.7, 6.10 LOAD Macro 6.2 LOCALE Processing with INCLUDE/OMIT 2.19 LOCALE Option 5.5, 7.57 LRECL 2.80, 2.89, 2.91, 2.138, 2.140 LRECL Parameter 4.4, 5.5, 5.24, 5.275.28, 5.31 LS Format 2.22, 2.32, 2.114, 2.117 M Macro Instructions (Assembler) 6.26.3 ATTACH Macro 6.2 LINK Macro 6.2 LOAD Macro 6.2 XCTL Macro 6.2 Masks 2.87 MAX 2.86 Maximums, Example 3.56 MAXSORT 2.66, 4.1, 4.7, 4.11, 9.19.23, 12.1 DD Statements for 4.16, 9.49.10 EXEC Statement for 4.3, 9.4 Exit Programs 9.13 File Size 4.7 Invoking from a Program 9.13 JCL/Control Stream Examples 9.179.23 Operator Interface 9.149.16 PARM Options 4.3, 5.1, 9.109.13 BKPTDSN 5.1, 9.10 DYNATAPE 5.1, 9.10, 9.149.16 MAXSORT 9.10 MAXWKSP 5.1, 9.11 MINWKSP 5.1, 9.11 NODYNATAPE 5.1, 9.10 RESTART 5.1, 9.12 SORTSIZE 5.1, 9.12 SORTTIME 5.1, 9.12 TAPENAME 5.1, 9.13 Performance Considerations 9.22, 13.1 PGM Names 4.3 Starting 9.139.14 Starting through JCL 9.4, 9.13 Summary of Control Statements for 2.8 Summary of the Chapter 1.8 Tuning 9.22 MAXSORT Option (MAXSORT) 9.10 MAXWKSP Option (MAXSORT) 5.1, 9.11 Merge
Index

JCL for PARASORT 10.2 See Job Control Language Job Control Language 4.1, 4.17 Control Statement Examples Copy without Exit Routines 4.264.27 Merge without Exit Routines 4.244.25 Multiple Output Files 4.334.34 Sort with Exit Routine to be Link-edited 4.304.32 Sort with Link-edited Exit Routine 4.284.29 Sorts without Exit Routines 4.23 DD Statement 4.1 Elements of 4.1 EXEC Statement 4.1, 5.1, 6.1 for HISTOGRM 14.4 for MAXSORT 9.4, 9.13 for Tape Sort 12.712.8 Initiating SyncSort 4.11, 6.1 JOB Statement 4.1 Sorts without Exit Routines 4.18 Summary of the Chapter 1.7 JOBLIB Statement 4.4 JOIN Control Statement 2.40 JOINKEYS 2.42 K KEY Messages L L6 Option 5.4, 5.18, 14.1 L7 Option 5.4, 14.1 LABEL Parameter 4.4, 5.27 Language Environment for MVS LENGTH 2.87 LENGTH Parameter (RECORD) LENGTH Subparameter 2.120 16.71

1.5, 5.19 2.1372.139

I.7

Creating Input Data Sets 4.7 Creating Input Records for Invoked Merge 7.5 Flow of 8.18.9 MERGE Control Statement 2.38, 2.462.60, 5.13, 5.16, 5.29, 6.2, 6.8, 7.5, 7.567.57 Merging 1.2 Phases of 1.2 Message Data Set 5.225.24 Messages 4.4, 5.7, 5.16, 5.215.22, 16.1 Authorization Messages 16.71 KEY Messages 16.71 PROC SYNCSORT Messages 16.7016.71 See FLAG Option Statistical Record Facility Messages 16.6916.70 Summary of the Chapter 1.8 MIN 2.86 Minimums, Example 3.56 MINWKSP Option (MAXSORT) 5.1, 9.11 Missing Field Bytes, Record 2.74 Mm Subparameter 2.121 MODS Control Statement 2.612.64, 5.14, 6.3, 6.5, 6.9, 7.3, 7.5, 7.87.9, 7.297.30, 12.6 MSG Option 5.4, 5.215.22, 6.10 MSGDD Option 5.4, 5.22, 7.10, 7.31 Multiple Lines, Record 2.74 Multiple Output 2.692.70, 3.623.64 Multiple Output Files 2.68 N National Language 1.5, 2.19, 2.46, 2.144, 5.19 with INCLUDE/OMIT 2.19 NOCOMMAREA Option 5.3, 5.10 NODETAIL Parameter (OUTFIL) 2.94 NODYNATAPE Option (MAXSORT) 5.1, 9.10 NOEQUALS Option 5.4, 5.14 NOIOERR Option 5.4, 5.17 NOLIST Option 5.4, 5.18 NORC16 Option 5.5 NORESET Option 5.5, 5.26 NORLSOUT Option 5.5, 5.26 Notational Conventions 2.14 NULLOFL Parameter (OUTFIL) 2.94, 2.105 NULLOUT Option 5.22 NZDPRINT 5.6 NZDPRINT Option 5.33

O OL Format 2.22, 2.32, 2.47, 2.114, 2.117, 2.146 OMIT Control Statement 2.65, 3.6 ONLY Parameter (JOIN) 2.41 Operator 2.102 Operator Interface 9.149.16 OPTCD Parameter 4.4 OR Operator 2.24, 3.3 OSCL Option 5.2, 6.7, 6.10, 12.312.5 OT 2.148 OT Format 2.22, 2.32, 2.49, 2.114, 2.117, 2.146 OUTFIL Control Statement 2.38, 2.662.96, 3.363.64, 6.2, 6.96.10, 13.2 OUTFIL Group 2.692.70 Output Data Sets 4.8, 4.10 See SORTOUT Files See SORTOUT Statement Output Files, Multiple 2.68, 3.623.64, 4.334.34 Output Lines, Multiple 2.74, 2.77, 3.37 Output Records Converting Data 3.293.36 Editing Data 3.323.36 Formatting 2.732.74, 2.972.136, 3.233.36 Output Records, Distributing 2.72 Output Reports 2.662.96, 3.393.64 Averaging Data 3.56 Ending Record Number 2.71 Headers 2.76, 2.80, 2.902.93, 3.413.50 Obtaining maximums 3.56 Obtaining minimums 3.56 Pages, Logical 2.912.93 Records Included 2.71 Saving Records 2.72 Sections 2.892.90, 3.393.41 Starting Record Number 2.71 Subtotaling Data 3.503.55 Totaling Data 3.503.55 Trailers 2.802.89, 2.912.93, 3.413.62 Output Space See Secondary Allocation OUTREC Control Statement 2.38, 2.972.136, 3.24, 6.96.10, 13.213.3 OUTREC Parameter (OUTFIL) 2.732.74 OVFLO option 5.23 P PAD Option 5.23

I.8

SyncSort for z/OS 1.2 Programmers Guide

PAGE (&PAGE) 2.80, 2.85 Pages, Defining Logical 2.912.93 Parameter List 24-bit 6.46.13, 7.3 Optional Parameters 6.8 31-bit 6.136.19, 7.3 Parameters Summary of the Chapter 1.7 Parameters (Control Statements) CKPT/CHKPT 2.58, 2.160 CODE 2.16 COND 2.202.37 CONVERT 2.75, 2.1283.36 DYNALLOC 2.1602.161 ENDREC 2.71 EQUALS/NOEQUALS 2.59, 2.161 Exit-Name 2.612.63 F1 2.40 F2 2.40 FIELDS 2.38, 2.43, 2.462.51, 2.992.128, 2.1442.159, 2.1642.165 FILE 2.43 FILES 2.59, 2.69, 3.623.64 FILL 2.142 FILSZ 2.162 FNAMES 2.70 FTOV 2.75 HEADER 13.3 HEADER1/HEADER2 2.762.80, 3.41 INCLUDE/OMIT 2.45, 2.702.71 LENGTH 2.1372.139 LINES 2.912.93 NODETAIL 2.94 NULLOFL 2.94, 2.105 ONLY 2.41 OUTREC 2.732.74, 13.3 REMOVECC 2.94 REPEAT 2.71 SAMPLE 2.71 SAVE 2.72 SECTIONS 2.892.90, 3.39, 13.3 SIZE 2.139, 2.162 SKIPREC 2.59, 2.162, 13.3 SORTED 2.44 SPLIT 2.722.73 SPLITBY 2.73 STARTREC 2.71 STOPAFT 2.60, 2.162, 13.3 TRAILER 13.3

TRAILER1/TRAILER2 2.802.89, 3.41, 3.58 TYPE 2.45, 2.137 UNPAIRED 2.40 VLFILL 2.74 VLTRIM 2.76 XSUM 2.165 Parameters (DD Statements) AMP 4.4 BLKSIZE 4.4, 5.5, 5.24, 5.275.28 BUFND 4.4 BUFNI 4.4 BUFOFF 4.4 BUFSP 4.4 DCB 4.4, 5.5, 5.24, 5.27 DISP 4.4, 5.27 DSNAME/DSN 4.4 LABEL 4.4, 5.27 LRECL 4.4, 5.5, 5.24, 5.275.28, 5.31 OPTCD 4.4 RECFM 4.4, 5.5, 5.24, 5.275.28 SPACE 4.4, 5.5, 5.25 UNIT 4.4 VOLUME/VOL 4.4 PARASORT 4.1, 4.7, 10.110.9 DD Statements for 4.16, 10.3 EXEC Statement for 10.2, 11.2 JCL for 10.2 JCL/Control Stream Examples 10.9 PARM Options 4.3 PARMS Options 5.2 PGM Names 4.3 SORTIN Statement for 10.3 Summary of the Chapter 1.8 PARASORT Sort DD Statements for 4.16 PARM Options 5.1 BALANCE 5.3, 5.7, 13.4 BALN 5.2, 6.7, 6.10, 12.312.5 BKPTDSN 5.1 BMSG 5.3, 5.7 CENTWIN ??2.502.51, 2.1492.159, 5.3, 5.75.9 CMP 13.3 CMP=CLC 2.50 CMP=CPD 2.50 COMMAREA 5.10, 7.4 CORE 5.11, 13.413.6 CPU 5.3, 5.7, 13.4
Index

I.9

CRCX 6.7, 6.10 DEBUG 5.12 DIAG 5.12, 6.7, 6.10 DYNALLOC 4.1, 5.125.13 DYNATAPE 4.1, 5.1 E15 5.14, 7.9 E35 5.14 ELAP 5.35.4, 5.7, 5.14, 13.4 EQUALS 5.4, 5.14, 13.3 EXTCOUNT 5.4, 5.15 FILSZ 5.4, 5.155.16 FLAG 5.4, 5.16, 6.10 for Disk Sort 5.1 for MAXSORT 5.1, 9.109.13 for PARASORT 5.2 for Tape Sort 5.2 Format of 5.1 HBSI 4.5, 5.4, 5.16 HBSO 4.10, 5.4, 5.17 IO 5.35.4, 5.7, 5.17, 13.4 IOERR 5.4, 5.17, 6.10 L6 5.4, 5.18, 14.1 L7 5.4, 14.1 LIST 5.4, 5.18, 6.7, 6.10 LOCALE 5.5, 7.57 MAXWKSP 5.1 MINWKSP 5.1 MSG 5.4, 5.215.22, 6.10 MSGDD 5.4, 5.22, 7.10, 7.31 NOCOMMAREA 5.10 NODYNATAPE 5.1 NOEQUALS 5.4, 5.14 NOIOERR 5.4, 5.17 NOLIST 5.4, 5.18 NORC16 5.5 NORESET 5.5, 5.26 NORLSOUT 5.5, 5.26 NULLOUT 5.22 NZDPRINT 5.6, 5.33 OSCL 5.2, 6.7, 6.10, 12.312.5 OVFLO 5.23 PAD 5.23 PEER 6.7, 6.10 POLY 5.2, 6.7, 6.10, 12.312.5 Precedence Rules 5.2 PRINT121 5.5 RC16 6.10 RELEASE 5.5

RESERVE 5.5, 5.25 RESERVEX 5.5, 5.26 RESET 5.5, 5.26 RESTART 5.1 RLSOUT 5.5, 5.26 SDB 5.5, 5.275.28 See $ORTPARM Statement SIZE 5.11 SKIPREC 5.5, 5.29, 7.52, 13.3 SORTSIZE 5.1 SORTTIME 5.1 Specification in JCL-initiated Applications 5.1 Specification in Program-initiated Applications 5.1 STOPAFT 5.5, 5.29, 13.3 Summarized 5.25.3 TAPENAME 5.1 TRUNC 5.29 UNINTDS 5.6, 5.30 VLTEST 5.5, 5.30, 13.3 VLTESTI 5.6, 5.32 VSAMEMT 5.6, 5.32 ZDPRINT 5.6, 5.33 PD Format 2.22, 2.32, 2.47, 2.50, 2.114, 2.117, 2.146, 2.149 PD0 Format 2.22, 2.32, 2.48, 2.54, 2.114, 2.117, 2.147, 2.153 PDID Format 2.113 PDIP Format 2.113 PEER Option 6.7, 6.10 Performance Considerations 13.113.14 Control of System Resource Usage 13.3 Control Statements 13.213.3 JCL- vs. Program-Invoked Sort 13.2 Memory Management 13.313.6 PARMS Options 13.3 Summary of the Chapter 1.8 Phases of Copying, Merging, Sorting 8.18.9 PipeSort 1.7, 2.68, 3.62, 15.3 PL/1 Programs 1.1, 6.1 POLY Option 5.2, 6.7, 6.10, 12.312.5 Precedence Rules 5.2 PRINT121 Option 5.5 PROC SYNCSORT - An Accelerator for SAS Sorting 1.7, 15.2 PROC SYNCSORT Messages 16.7016.71 Product Services 16.77

I.10

SyncSort for z/OS 1.2 Programmers Guide

Program Exits See Exit Programs R RC16 Option 6.10 RDW 2.12, 2.138 RECFM Parameter 4.4, 5.5, 5.24, 5.275.28 RECORD Control Statement 2.1372.140, 6.3, 12.6 Record Counts 3.583.62 Record Format 2.1372.140 Record Length 2.1372.140 Maximum for Fixed-Length Records 4.5 Maximum for Variable-Length Records 4.5 Record Selection 2.192.37, 2.592.60, 2.702.71, 2.162, 3.23.11, 5.29 Using Bit Level Logic 2.342.36 Records, Distributing Output 2.72 Reference Guide 1.9 REFORMAT Control Statement 2.141 Reformatting Records 2.382.39, 2.732.74, 2.972.136, 3.243.27 CHANGE Subparameter 2.125 Column Alignment 2.77 Data Conversion and Editing 2.1102.133, 3.293.36 Inserting Binary Zeros 2.115, 3.28 Inserting Blanks or Spaces 2.115 Inserting Hexadecimal Characters 2.115 Inserting Literal Characters 2.115 Missing Field Bytes 2.74 OUTREC Parameter 2.732.74 Record on Multiple Lines 2.74 Replace 2.125 Search and Replace 2.125 Variable-Length Records 2.99 Register Conventions 7.4 Registers See Register Conventions RELEASE Option 5.5 REMOVECC Parameter (OUTFIL) 2.94 REPEAT Parameter (OUTFIL) 2.71 Replace 2.125 Report Writing 2.68, 2.762.96, 3.393.64 Repositioning Record Fields 3.243.27 RESERVE Option 5.5, 5.25 RESERVEX Option 5.5, 5.26

RESET Option 5.5, 5.26 RESTART Option (MAXSORT) 5.1, 9.12 RETRY 2.161, 5.13 Return Codes 6.10, 6.16 REXX Exits 2.62, 7.587.60 REXX Programs 1.1 RLSOUT Option 5.5, 5.26 Run-Time Constants, Generating 2.116 S SAMPLE Parameter (OUTFIL) 2.71 SAVE Parameter (OUTFIL) 2.72 SC 2.161, 5.13 SDB 4.19, 4.21, 4.23, 4.26, 4.31, 5.27 SDB Option 5.5, 5.275.28 Search and Replace 2.125 Secondary Allocation 4.10 SECTIONS Parameter (OUTFIL) 2.892.90, 3.39 SEQNUM 2.38, 2.115 SIGNS 2.87 SIZE Option 5.3, 5.11 SIZE Parameter (SORT) 2.139, 2.162 SKIPREC Option 5.5, 5.29, 7.52, 13.3 SKIPREC Parameter (MERGE) 2.59 SKIPREC Parameter (SORT) 2.162 SMF Formats 2.114 SMF Formats, Converting 2.114 SNAP Dump 5.12 Sort Creating Input Data Sets for 4.5 Flow of 8.18.9 Sort Control Summary of the Chapter 1.8 SORT Control Statement 2.38, 2.1442.163, 5.13, 5.16, 5.29, 6.2, 7.52, 7.567.57, 12.6 SORT/MERGE 6.26.4 SORT/MERGE Options Precedence Rules 5.2 SORTBKPT Statement 9.69.7 SORTCKPT Statement 4.1, 4.15 SORTED Parameter (JOINKEYS) 2.44 SORTIN End-of-File 7.9, 7.13 SORTIN File 4.1, 4.5, 5.4, 5.16, 6.8, 6.13, 6.18, 7.7, 7.97.13, 7.51 SORTIN Processing 7.527.53 SORTIN Statement 4.1, 4.54.7, 5.27, 6.2, 7.8, 10.3
Index

I.11

for PARASORT 10.3 Sorting Phases of 1.2 Types of 1.2 Sorting Technique Disk Sort 4.1, 12.1, 13.1 MAXSORT 4.1, 4.7, 4.11, 4.16, 9.19.23, 12.1, 13.1 PARASORT 4.1, 4.16, 10.110.9 Performance Considerations 13.1, 13.14 Tape Sort 4.1, 4.11, 4.16, 12.1, 12.11, 13.1 Balanced (BALN) 12.412.5 Oscillating (OSCL) 12.412.5 Polyphase (POLY) 12.412.5 SORTINn Statement 4.1, 4.7 SORTINnn Statement 4.7 SORTINnn File 5.145.15, 7.6 SORTINnn Statement 4.1, 4.7, 6.2, 7.5 SORTJNF1 Statement 4.8 SORTJNF2 Statement 4.8 SORTLIB Statement 6.2, 12.3 SORTMODS Library 7.3 SORTMODS Statement 4.1, 4.15 SORTOFx File 5.265.28 SORTOFx Statement 4.1, 4.8, 6.2 SORTOFxx File 5.5, 5.265.27, 7.30, 7.35 SORTOFxx Statement 4.1, 4.8, 6.2 SORTOU00 Statement 9.79.9 SORTOUT File 4.1, 4.8, 5.45.5, 5.17, 5.265.28, 7.30, 7.35, 7.52 SORTOUT Files 6.2 SORTOUT Space 5.5, 5.26 SORTOUT Statement 4.1, 4.8, 6.2, 7.29 SORTOUT VSAM File 5.26 SORTOUT Write Errors 7.55 SORTPARn Statement 10.510.7 SORTSIZE Option (MAXSORT) 5.1, 9.12 SORTTIME Option (MAXSORT) 5.1, 9.12 SORTWK Dynamic Allocation of 5.12 SORTWK Requirements 12.4 SORTWKnn File 7.6 SORTWKnn Statement 4.1, 4.104.11, 6.2, 12.412.5 Conditions of Use 4.104.11 See DYNALLOC Option SortWriter 2.66, 2.68, 2.76 Sample Report 1.5 SORTXSUM 4.8, 5.26

SORTXSUM Statement 6.2 SPACE Parameter 4.4, 5.5, 5.25 Special Esoteric Names 10.7 SPLIT Parameter (OUTFIL) 2.722.73 SPLITBY Parameter (OUTFIL) 2.73 Starting SyncSort 1.1 Summary of the Chapter 1.7 STARTREC Parameter (OUTFIL) 2.71 Statistical Record Facility Messages 16.6916.70 STEPBLIB Statement 4.1 STEPLIB Statement 4.4 STOPAFT Option 5.5, 5.29, 13.3 STOPAFT Parameter (MERGE) 2.60 STOPAFT Parameter (SORT) 2.162 Storage Disk 4.10 Intermediate 4.104.11, 12.4 SUBAVG 2.86 SUBCOUNT 2.88 SUBCOUNT15 2.88 SUBMAX 2.86 SUBMIN 2.86 Substring Comparison 2.33 SUBTOTAL 2.85 SUM Control Statement 2.38, 2.1642.167, 3.11, 5.14, 5.16, 6.9, 7.27, 13.2 SyncSort Data Utility 1.3, 3.13.64 Description of 1.1 Features of 1.11.6 Initiation of 1.1 SortWriter 1.5 SyncSort Messages 4.4 SYSIN Statement 4.1, 4.11 SYSLIN Statement 4.1, 4.15 SYSLMOD Statement 4.1, 4.16 SYSOUT See Message Data Set SYSOUT Statement 4.1, 4.4, 6.2 SYSPRINT Statement 4.1, 4.16 System Abend (0C7) 5.9, 5.31 SYSUT1 Statement 4.1, 4.16 T Tape Sort 4.1, 4.15, 12.112.11 Control Statements for 12.6 Converting to MAXSORT 13.2

I.12

SyncSort for z/OS 1.2 Programmers Guide

DD Statements for 4.17, 12.312.5 Device Types 4.11 Devices 12.4 EXEC Statement 12.212.3 EXEC Statement for 4.3 Invoking from a Program 12.912.11 JCL/Control Stream Examples 12.712.8 PARM Options 4.3, 12.2 BALN 5.2, 12.312.5 OSCL 5.2, 12.312.5 POLY 5.2, 12.312.5 PARMS Options 5.2 Performance Considerations 13.1 PGM Names 4.3 Starting 4.11, 12.712.11 Starting through JCL 12.712.8 Summary of Control Statements for 2.8 Summary of Restrictions 12.112.2 TAPENAME Option (MAXSORT) 5.1, 9.13 Technical Support 16.77 TIME (&TIME) 2.79, 2.84, 2.117 TM1 2.114 TM2 2.114 TM3 2.114 TM4 2.114 TOTAL 2.85 TRAILER1/TRAILER2 Parameter (OUTFIL) 2.802.89, 3.41, 3.58 TRAN subparameter 2.105 TRUNC Option 5.29 TS Format 2.22, 2.32, 2.47, 2.114, 2.117, 2.146 TYPE Parameter (JOINKEYS) 2.45 TYPE Parameter (RECORD) 2.137 U UNINTDS Option 4.7, 5.3, 5.6, 5.30 UNIT Parameter 4.4 UNPAIRED Parameter (JOIN) 2.40 V Value-Added Products 1.61.7, 15.115.3 PipeSort 1.7, 15.3 PROC SYNCSORT - An Accelerator for SAS Sorting 1.7, 15.2 Summary of the Chapter 1.8 Variable-Length Records 2.12, 2.50, 2.99, 2.128, 2.137, 3.93.11, 7.117.12, 7.177.19,

7.337.34, 7.407.42 Maximum Length 4.5 See VLTEST Option Validity Testing 5.30 Visual SyncSort 1.6, 15.1 VLFILL Parameter (OUTFIL) 2.74 VLTEST Option 5.3, 5.5, 5.30, 13.3 VLTESTI Option 5.3, 5.6, 5.32 VLTRIM Parameter (OUTFIL) 2.76 VOL Parameter See VOLUME Parameter VOLUME Parameter 4.4 VSAM 4.5, 4.8, 5.26, 7.547.55 RECORD Control Statement 2.137 See also RESET Option VSAM SORTOUT 5.5 VSAMEMT Option 5.6, 5.32 W Work Areas See SORTWKnn Statement Work Space 5.18, 5.255.27 X XCTL Macro 6.2, 7.8, 7.29 XSUM Parameter (SUM) 2.165 Y YDATEx 2.312.33 Y2B Format 2.22, 2.32, 2.48, 2.51, 2.1132.114, 2.117, 2.147, 2.149 Y2C Format 2.22, 2.32, 2.48, 2.52, 2.1132.114, 2.117, 2.147, 2.150 Y2D Format 2.22, 2.32, 2.49, 2.52, 2.1132.114, 2.117, 2.147, 2.150 Y2P Format 2.22, 2.32, 2.49, 2.52, 2.1132.114, 2.117, 2.147, 2.151 Y2S Format 2.22, 2.32, 2.49, 2.53, 2.1132.114, 2.117, 2.147, 2.151 Y2T Format 2.22, 2.32, 2.49, 2.54, 2.1132.114, 2.117, 2.147, 2.149, 2.154 Y2U Format 2.22, 2.32, 2.49, 2.54, 2.1132.114, 2.117, 2.147, 2.149, 2.154 Y2V Format 2.22, 2.32, 2.49, 2.54, 2.1132.114, 2.117, 2.147, 2.149, 2.154
Index

I.13

Y2W Format 2.22, 2.32, 2.49, 2.54, 2.1132.114, 2.117, 2.147, 2.149, 2.154 Y2X Format 2.22, 2.32, 2.49, 2.54, 2.1132.114, 2.117, 2.147, 2.149, 2.154 Y2Y Format 2.22, 2.32, 2.49, 2.54, 2.1132.114, 2.117, 2.147, 2.149, 2.154 Y2Z Format 2.22, 2.32, 2.49, 2.52, 2.1132.114, 2.117, 2.148, 2.150 Year Data, Converting 2.1122.114 Z ZD Format 2.22, 2.32, 2.492.50, 2.114, 2.117, 2.146, 2.1482.149 ZDPRINT 5.6 ZDPRINT Option 5.33 ZSPACE 1.6, 16.54

I.14

SyncSort for z/OS 1.2 Programmers Guide

We welcome comments on the usefulness and readability of this Manual. Your comments, along with suggested additions or deletions, will help us to improve future editions of the publications. If you would like a reply, please indicate your name, business title, and business address. All comments and suggestions become the property of Syncsort Incorporated.

READERS' COMMENTS
SyncSort for z/OS Programmer's Guide SI-4301-6

Fold the form on the two lines, staple, and mail. No postage stamp is necessary if form is mailed in the United States.

Fold

Fold No postage necessary if mailed in the United States

BUSINESS REPLY MAIL


FIRST CLASS PERMIT NO. 80 WOODCLIFF LAKE, NJ POSTAGE WILL BE PAID BY ADDRESSEE

Syncsort Incorporated SyncSort for z/OS Product Services 50 Tice Boulevard Woodcliff Lake, NJ 07677

Fold

Fold

You might also like