JCL - Astuces de tri de base
Les exigences des applications quotidiennes dans un monde d'entreprise qui peuvent être atteintes à l'aide de programmes utilitaires sont illustrées ci-dessous:
1. A file has 100 records. The first 10 records need to be written to output file.
//JSTEP020 EXEC PGM=ICETOOL
//TOOLMSG DD SYSOUT=*
//DFSMSG DD SYSOUT=*
//IN1 DD DSN=MYDATA.URMI.STOPAFT,DISP=SHR
//OUT1 DD SYSOUT=*
//TOOLIN DD *
COPY FROM(IN1) TO(OUT1) USING(CTL1)
/*
//CTL1CNTL DD *
OPTION STOPAFT=10
/*
L'option STOPAFT arrêtera la lecture du fichier d'entrée après le 10e enregistrement et terminera le programme. Par conséquent, 10 enregistrements sont écrits en sortie.
2. Input file has one or more records for same employee number. Write unique records to output.
//STEP010 EXEC PGM=SORT
//SYSOUT DD SYSOUT=*
//SORTIN DD DSN=MYDATA.URMI.DUPIN,DISP=SHR
//SORTOUT DD SYSOUT=*
//SYSIN DD *
SORT FIELDS=(1,15,ZD,A)
SUM FIELDS=NONE
/*
SUM FIELDS = NONE supprime les doublons sur les champs spécifiés dans SORT FIELDS. Dans l'exemple ci-dessus, le numéro d'employé est dans la position de champ 1,15. Le fichier de sortie contiendra les numéros d'employés uniques triés par ordre croissant.
3. Overwrite input record content.
//JSTEP010 EXEC PGM=SORT
//SORTIN DD DSN= MYDATA.URMI.SAMPLE.MAIN,DISP=SHR
//SORTOUT DD SYSOUT=*
//SYSPRINT DD SYSOUT=*
//SYSOUT DD SYSOUT=*
//SYSIN DD *
OPTION COPY
INREC OVERLAY=(47:1,6)
/*
Dans le fichier d'entrée, le contenu en position 1,6 est écrasé à la position 47,6 puis copié dans le fichier de sortie. L'opération INREC OVERLAY est utilisée pour réécrire les données dans le fichier d'entrée avant de les copier vers la sortie.
4. Adding a sequence number to the output file.
//JSTEP010 EXEC PGM=SORT
//SORTIN DD *
data1
data2
data3
/*
//SORTOUT DD SYSOUT=*
//SYSPRINT DD SYSOUT=*
//SYSOUT DD SYSOUT=*
//SYSIN DD *
OPTION COPY
BUILD=(1:1,5,10:SEQNUM,4,ZD,START=1000,INCR=2)
/*
La sortie sera:
data1 1000
data2 1002
data3 1004
Un numéro de séquence à 4 chiffres est ajouté dans la sortie à la position 10, commençant à 1000 et incrémenté de 2 pour chaque enregistrement.
5. Adding Header/Trailer to output file.
//JSTEP010 EXEC PGM=SORT
//SORTIN DD *
data1
data2
data3
/*
//SORTOUT DD SYSOUT=*
//SYSPRINT DD SYSOUT=*
//SYSOUT DD SYSOUT=*
//SYSIN DD *
SORT FIELDS=COPY
OUTFIL REMOVECC,
HEADER1=(1:C'HDR',10:X'020110131C'),
TRAILER1=(1:C'TRL',TOT=(10,9,PD,TO=PD,LENGTH=9))
/*
La sortie sera:
HDR 20110131
data1
data2
data3
TRL 000000003
TOT calcule le nombre d'enregistrements dans le fichier d'entrée. HDR et TRL sont ajoutés en tant qu'identificateurs à l'en-tête / à la fin, qui est défini par l'utilisateur et peut être personnalisé selon les besoins des utilisateurs.
6. Conditional Processing
//JSTEP010 EXEC PGM=SORT
//SORTIN DD *
data1select
data2
data3select
/*
//SORTOUT DD SYSOUT=*
//SYSPRINT DD SYSOUT=*
//SYSOUT DD SYSOUT=*
//SYSIN DD *
INREC IFTHEN=(WHEN=(6,1,CH,NE,C' '),BUILD=(1:1,15),
IFTHEN=(WHEN=(6,1,CH,EQ,C' '),BUILD=(1:1,5,7:C'EMPTY ')
OPTION COPY
/*
La sortie sera:
data1select
data2 EMPTY
data3select
En fonction de la 6ème position du fichier, la BUILD du fichier de sortie varie. Si la 6ème position est ESPACES, alors le texte "VIDE" est ajouté à l'enregistrement d'entrée. Sinon, l'enregistrement d'entrée est écrit dans la sortie, tel quel.
7. Backing up a file
//JSTEP001 EXEC PGM=IEBGENER
//SYSPRINT DD SYSOUT=*
//SYSIN DD *
//SYSOUT DD SYSOUT=*
//SORTOUT DD DUMMY
//SYSUT1 DD DSN=MYDATA.URMI.ORIG,DISP=SHR
//SYSUT2 DD DSN=MYDATA.URMI.BACKUP,DISP=(NEW,CATLG,DELETE),
// DCB=*.SYSUT1,SPACE=(CYL,(50,1),RLSE)
IEBGENER copie le fichier dans SYSUT1 dans un fichier dans SYSUT2. Veuillez noter que le fichier dans SYSUT2 prend le même DCB que celui de SYSUT1 dans l'exemple ci-dessus.
8. File Comparison
//STEP010 EXEC PGM=SORT
//MAIN DD *
1000
1001
1003
1005
//LOOKUP DD *
1000
1002
1003
//MATCH DD DSN=MYDATA.URMI.SAMPLE.MATCH,DISP=OLD
//NOMATCH1 DD DSN=MYDATA.URMI.SAMPLE.NOMATCH1,DISP=OLD
//NOMATCH2 DD DSN=MYDATA.URMI.SAMPLE.NOMATCH2,DISP=OLD
//SYSOUT DD SYSOUT=*
//SYSIN DD *
JOINKEYS F1=MAIN,FIELDS=(1,4,A)
JOINKEYS F2=LOOKUP,FIELDS=(1,4,A)
JOIN UNPAIRED,F1,F2
REFORMAT FIELDS=(?,F1:1,4,F2:1,4)
OPTION COPY
OUTFIL FNAMES=MATCH,INCLUDE=(1,1,CH,EQ,C'B'),BUILD=(1:2,4)
OUTFIL FNAMES=NOMATCH1,INCLUDE=(1,1,CH,EQ,C'1'),BUILD=(1:2,4)
OUTFIL FNAMES=NOMATCH2,INCLUDE=(1,1,CH,EQ,C'2'),BUILD=(1:2,4)
/*
JOINKEYS spécifie le champ sur lequel les deux fichiers sont comparés.
CHAMPS DE REFORMAT =? place 'B' (enregistrements correspondants), '1' (présent dans fichier1, mais pas dans fichier2) ou '2' (présent dans fichier2 mais pas dans fichier1) à la 1ère position de la sortie BUILD.
JOIN UNPAIRED effectue une jointure externe complète sur les deux fichiers.
La sortie sera:
MATCH File
1000
1003
NOMATCH1 File
1001
1005
NOMATCH2 File
1002
La même fonctionnalité peut également être obtenue en utilisant ICETOOL.