Le tri des données dans un fichier ou la fusion de deux fichiers ou plus est un besoin courant dans presque toutes les applications métier.
Le tri est utilisé pour classer les enregistrements dans l’ordre croissant ou décroissant afin qu’un traitement séquentiel puisse être effectué. Deux techniques sont utilisées pour classer les fichiers en COBOL :
- Le tri externe est utilisé pour trier les fichiers à l’aide de l’utilitaire SORT dans le JCL. Nous en parlons dans le chapitre JCL.
Désormais, nous nous concentrerons sur le classement interne.
- Le tri interne est utilisé pour trier les fichiers dans un programme COBOL.
Le verbe SORT est utilisé pour trier un fichier.
SORT
Trois fichiers sont utilisés dans le processus de classification en COBOL :
- Le fichier d’entrée est le fichier que nous devons trier par ordre croissant ou décroissant.
- Le fichier de travail est utilisé pour conserver des enregistrements pendant que le processus de tri est en cours. Les enregistrements du fichier d’entrée sont transférés dans le fichier de travail pour le processus de classification. Ce fichier doit être défini dans la section Fichier de l’entrée SD.
- Le fichier de sortie est le fichier que nous obtenons après le processus de classification. C’est la sortie finale du verbe Sort.
Syntaxe
Voici la syntaxe pour trier un fichier :
SORT TEST-FIC ON ASCENDING KEY REC-CLE1
[ON DESCENDING KEY REC-CLE2]
USING ENTREE-FIC GIVING SORTIE-FIC.
SORT effectue les opérations suivantes :
- Ouvre le fichier de travail en mode IO, le fichier d’entrée en mode INPUT et le fichier de sortie en mode OUTPUT.
Transfère les enregistrements présents dans le fichier d’entrée vers le fichier de travail.
- Trie le FICHIER DE TRI dans l’ordre croissant/décroissant par clé d’enregistrement.
- Transfère les enregistrements triés du fichier de travail vers le fichier de sortie.
- Ferme le fichier d’entrée et le fichier de sortie et supprime le fichier de travail.
Exemple
Dans l’exemple suivant, INPUT est le fichier d’entrée qui doit être trié par ordre croissant :
IDENTIFICATION DIVISION.
PROGRAM-ID. SORT.
ENVIRONMENT DIVISION.
INPUT-OUTPUT SECTION.
FILE-CONTROL.
SELECT ENTREE ASSIGN TO IN.
SELECT SORTIE ASSIGN TO OUT.
SELECT TRAVAIL ASSIGN TO WRK.
DATA DIVISION.
FILE SECTION.
FD ENTREE.
01 ENTREE-ETUDIANT
.
05 ETUDIANT
-ID-I PIC 9(05).
05 ETUDIANT
-NAME-I PIC A(25).
FD SORTIE.
01 SORTIE-ETUDIANT.
05 STUDENT-ID-O PIC 9(05).
05 STUDENT-NAME-O PIC A(25).
SD TRAVAIL.
01 TRAVAIL-ETUDIANT.
05 ETUDIANT-ID-W PIC 9(05).
05 ETUDIANT-NOM-W PIC A(25).
PROCEDURE DIVISION.
SORT TRAVAIL ON ASCENDING KEY ETUDIANT
-ID-O
USING ENTREE GIVING SORTIE.
DISPLAY 'Sort Successful'.
STOP RUN.
JCL pour l’exécution du programme COBOL :
//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM=CADSORT
//IN DD DSN=ENTREE-NOM-FICHIER,DISP=SHR
//OUT DD DSN=SORTIE-NOM-FICHIER,DISP=SHR
//WRK DD DSN=&&TEMP
Lorsque vous compilez et exécutez le programme ci-dessus, il produit le résultat suivant :
Sort Successful
MERGE
Deux ou plusieurs fichiers séquencés de manière identique sont combinés à l’aide de l’instruction Merge. Fichiers utilisés dans le processus de fusion :
- Fichiers d’entrée : Entrée-1, Entrée-2
- Fichier de travail
- Fichier de sortie
Syntaxe
Voici la syntaxe pour fusionner deux ou plusieurs fichiers :
MERGE TRAVAIL-FIC ON ASCENDING KEY REC-CLE1
[ON DESCENDING KEY REC-CLE2]
USING ENTREE-1, ENTREE-2 GIVING SORTIE-FIC.
Fusionner (MERGE) effectue les opérations suivantes :
- Ouvre le fichier de travail en mode IO, les fichiers d’entrée en mode INPUT et le fichier de sortie en mode OUTPUT.
- Transfère les enregistrements présents dans les fichiers d’entrée vers le fichier de travail.
- Trie le SORT-FIC dans l’ordre croissant/décroissant par REC-CLE.
- Transfère les enregistrements triés du fichier de travail vers le fichier de sortie.
- Ferme le fichier d’entrée et le fichier de sortie et supprime le fichier de travail.
Exemple
Dans l’exemple suivant, ENTREE1 et ENTREE2 sont les fichiers d’entrée qui doivent être fusionnés dans l’ordre croissant :
IDENTIFICATION DIVISION.
PROGRAM-ID. SORT.
ENVIRONMENT DIVISION.
INPUT-OUTPUT SECTION.
FILE-CONTROL.
SELECT ENTREE1 ASSIGN TO IN1.
SELECT ENTREE2 ASSIGN TO IN2.
SELECT SORTIE ASSIGN TO OUT.
SELECT TRAVAIL ASSIGN TO WRK.
DATA DIVISION.
FILE SECTION.
FD ENTREE1.
01 ENTREE1-ETUDIANT.
05 ETUDIANT-ID-I1 PIC 9(05).
05 ETUDIANT-NOM-I1 PIC A(25).
FD ENTREE2.
01 ENTREE2-ETUDIANT.
05 ETUDIANT-ID-I2 PIC 9(05).
05 ETUDIANT-NOM-I2 PIC A(25).
FD SORTIE.
01 SORTIE-ETUDIANT.
05 ETUDIANT-ID-O PIC 9(05).
05 ETUDIANT-NOM-O PIC A(25).
SD TRAVAIL.
01 TRAVAIL-ETUDIANT.
05 ETUDIANT-ID-W PIC 9(05).
05 ETUDIANT-NOM-W PIC A(25).
PROCEDURE DIVISION.
MERGE TRAVIL ON ASCENDING KEY ETUDIANT-ID-O
USING ENTREE1, ENTREE2 GIVING SORTIE.
DISPLAY 'Merge Successful'.
STOP RUN.
JCL pour l’exécution du programme COBOL :
//EXEMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM=SORT
//IN1 DD DSN=ENTREE1-NOM-FICHIER
,DISP=SHR
//IN2 DD DSN=ENTREE2-NOM-FICHIER
,DISP=SHR
//OUT DD DSN=SORTIE-NOM-FICHIER
,DISP=SHR
//WRK DD DSN=&&TEMP
Lorsque vous compilez et exécutez le programme ci-dessus, il produit le résultat suivant :
Merge Successful