COBOL - Tri interne
Le tri des données dans un fichier ou la fusion de deux fichiers ou plus est une nécessité courante dans presque toutes les applications professionnelles. Le tri est utilisé pour organiser les enregistrements par ordre croissant ou décroissant, de sorte qu'un traitement séquentiel puisse être effectué. Il existe deux techniques utilisées pour trier les fichiers en COBOL -
External sortest utilisé pour trier les fichiers à l'aide de l'utilitaire SORT dans JCL. Nous en avons discuté dans le chapitre JCL. À partir de maintenant, nous nous concentrerons sur le tri interne.
Internal sort est utilisé pour trier les fichiers dans un programme COBOL. SORT verb est utilisé pour trier un fichier.
Trier le verbe
Trois fichiers sont utilisés dans le processus de tri en COBOL -
Input file est le fichier que nous devons trier par ordre croissant ou décroissant.
Work fileest utilisé pour conserver les 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 tri. Ce fichier doit être défini dans la section Fichier sous l'entrée SD.
Output fileest le fichier que nous obtenons après le processus de tri. C'est la sortie finale du verbe Sort.
Syntaxe
Voici la syntaxe pour trier un fichier -
SORT work-file ON ASCENDING KEY rec-key1
[ON DESCENDING KEY rec-key2]
USING input-file GIVING output-file.
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 SORT-FILE dans l'ordre croissant / décroissant par rec-key.
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.
Example
Dans l'exemple suivant, INPUT est le fichier d'entrée qui doit être trié par ordre croissant -
IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.
ENVIRONMENT DIVISION.
INPUT-OUTPUT SECTION.
FILE-CONTROL.
SELECT INPUT ASSIGN TO IN.
SELECT OUTPUT ASSIGN TO OUT.
SELECT WORK ASSIGN TO WRK.
DATA DIVISION.
FILE SECTION.
FD INPUT.
01 INPUT-STUDENT.
05 STUDENT-ID-I PIC 9(5).
05 STUDENT-NAME-I PIC A(25).
FD OUTPUT.
01 OUTPUT-STUDENT.
05 STUDENT-ID-O PIC 9(5).
05 STUDENT-NAME-O PIC A(25).
SD WORK.
01 WORK-STUDENT.
05 STUDENT-ID-W PIC 9(5).
05 STUDENT-NAME-W PIC A(25).
PROCEDURE DIVISION.
SORT WORK ON ASCENDING KEY STUDENT-ID-O
USING INPUT GIVING OUTPUT.
DISPLAY 'Sort Successful'.
STOP RUN.
JCL pour exécuter le programme COBOL ci-dessus -
//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO
//IN DD DSN = INPUT-FILE-NAME,DISP = SHR
//OUT DD DSN = OUTPUT-FILE-NAME,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 Verb
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 - Input-1, Input-2
- Fichier de travail
- Fichier de sortie
Syntaxe
Voici la syntaxe pour fusionner deux fichiers ou plus -
MERGE work-file ON ASCENDING KEY rec-key1
[ON DESCENDING KEY rec-key2]
USING input-1, input-2 GIVING output-file.
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 fichier SORT-FILE dans l'ordre croissant / décroissant par rec-key.
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.
Example
Dans l'exemple suivant, INPUT1 et INPUT2 sont les fichiers d'entrée qui doivent être fusionnés dans l'ordre croissant -
IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.
ENVIRONMENT DIVISION.
INPUT-OUTPUT SECTION.
FILE-CONTROL.
SELECT INPUT1 ASSIGN TO IN1.
SELECT INPUT2 ASSIGN TO IN2.
SELECT OUTPUT ASSIGN TO OUT.
SELECT WORK ASSIGN TO WRK.
DATA DIVISION.
FILE SECTION.
FD INPUT1.
01 INPUT1-STUDENT.
05 STUDENT-ID-I1 PIC 9(5).
05 STUDENT-NAME-I1 PIC A(25).
FD INPUT2.
01 INPUT2-STUDENT.
05 STUDENT-ID-I2 PIC 9(5).
05 STUDENT-NAME-I2 PIC A(25).
FD OUTPUT.
01 OUTPUT-STUDENT.
05 STUDENT-ID-O PIC 9(5).
05 STUDENT-NAME-O PIC A(25).
SD WORK.
01 WORK-STUDENT.
05 STUDENT-ID-W PIC 9(5).
05 STUDENT-NAME-W PIC A(25).
PROCEDURE DIVISION.
MERGE WORK ON ASCENDING KEY STUDENT-ID-O
USING INPUT1, INPUT2 GIVING OUTPUT.
DISPLAY 'Merge Successful'.
STOP RUN.
JCL pour exécuter le programme COBOL ci-dessus -
//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO
//IN1 DD DSN=INPUT1-FILE-NAME,DISP=SHR
//IN2 DD DSN=INPUT2-FILE-NAME,DISP=SHR
//OUT DD DSN = OUTPUT-FILE-NAME,DISP=SHR
//WRK DD DSN = &&TEMP
Lorsque vous compilez et exécutez le programme ci-dessus, il produit le résultat suivant -
Merge Successful