COBOL - Guide rapide

Introduction à COBOL

COBOL est un langage de haut niveau. Il faut comprendre le fonctionnement de COBOL. Les ordinateurs ne comprennent que le code machine, un flux binaire de 0 et 1. Le code COBOL doit être converti en code machine à l'aide d'uncompiler. Exécutez la source du programme via un compilateur. Le compilateur vérifie d'abord les erreurs de syntaxe, puis le convertit en langage machine. Le compilateur crée un fichier de sortie appeléload module. Ce fichier de sortie contient du code exécutable sous la forme de 0 et de 1.

Évolution de COBOL

Au cours des années 1950, lorsque les entreprises se développaient dans la partie occidentale du monde, il était nécessaire d'automatiser divers processus pour en faciliter l'utilisation, ce qui a donné naissance à un langage de programmation de haut niveau destiné au traitement des données d'entreprise.

  • En 1959, COBOL a été développé par CODASYL (Conference on Data Systems Language).

  • La version suivante, COBOL-61, est sortie en 1961 avec quelques révisions.

  • En 1968, COBOL a été approuvé par l'ANSI comme langage standard à usage commercial (COBOL-68).

  • Il a été à nouveau révisé en 1974 et 1985 pour développer des versions ultérieures nommées COBOL-74 et COBOL-85 respectivement.

  • En 2002, COBOL orienté objet a été publié, qui pourrait utiliser des objets encapsulés comme une partie normale de la programmation COBOL.

Importance de COBOL

  • COBOL a été le premier langage de programmation de haut niveau largement utilisé. C'est une langue de type anglais qui est conviviale. Toutes les instructions peuvent être codées en mots anglais simples.

  • COBOL est également utilisé comme langage auto-documenté.

  • COBOL peut gérer d'énormes traitements de données.

  • COBOL est compatible avec ses versions précédentes.

  • COBOL a des messages d'erreur efficaces et ainsi, la résolution des bogues est plus facile.

Caractéristiques de COBOL

Langue standard

COBOL est un langage standard qui peut être compilé et exécuté sur des machines telles que IBM AS / 400, des ordinateurs personnels, etc.

Orienté vers le business

COBOL a été conçu pour les applications commerciales liées au domaine financier, au domaine de la défense, etc. Il peut traiter d'énormes volumes de données grâce à ses capacités avancées de traitement de fichiers.

Langage robuste

COBOL est un langage robuste car ses nombreux outils de débogage et de test sont disponibles pour presque toutes les plates-formes informatiques.

Langage structuré

Des structures de contrôle logiques sont disponibles dans COBOL, ce qui facilite la lecture et la modification. COBOL a différentes divisions, il est donc facile à déboguer.

Installation de COBOL sur Windows / Linux

Il existe de nombreux émulateurs mainframe gratuits disponibles pour Windows qui peuvent être utilisés pour écrire et apprendre des programmes COBOL simples.

Un tel émulateur est Hercules, qui peut être facilement installé sur Windows en suivant quelques étapes simples comme indiqué ci-dessous -

  • Téléchargez et installez l'émulateur Hercules, disponible sur le site d'accueil d'Hercules: www.hercules-390.eu

  • Une fois que vous avez installé le package sur la machine Windows, il créera un dossier comme C:/hercules/mvs/cobol.

  • Exécutez l'invite de commande (CMD) et accédez au répertoire C: / hercules / mvs / cobol sur CMD.

  • Le guide complet sur les différentes commandes pour écrire et exécuter des programmes JCL et COBOL est disponible à l'adresse:

    www.jaymoseley.com/hercules/installmvs/instmvs2.htm

Hercules est une implémentation logicielle open source des architectures mainframe System / 370 et ESA / 390, en plus de la dernière architecture z / 64 bits. Hercules fonctionne sous Linux, Windows, Solaris, FreeBSD et Mac OS X.

Un utilisateur peut se connecter à un serveur mainframe de différentes manières, telles qu'un client léger, un terminal factice, un système de client virtuel (VCS) ou un système de bureau virtuel (VDS). Chaque utilisateur valide reçoit un identifiant de connexion pour entrer dans l'interface Z / OS (TSO / E ou ISPF).

Compilation de programmes COBOL

Afin d'exécuter un programme COBOL en mode batch à l'aide de JCL, le programme doit être compilé et un module de chargement est créé avec tous les sous-programmes. Le JCL utilise le module de chargement et non le programme réel au moment de l'exécution. Les bibliothèques de chargement sont concaténées et transmises au JCL au moment de l'exécution à l'aide deJCLLIB ou STEPLIB.

Il existe de nombreux utilitaires de compilation mainframe disponibles pour compiler un programme COBOL. Certaines entreprises utilisent des outils de gestion du changement commeEndevor, qui compile et stocke chaque version du programme. Ceci est utile pour suivre les modifications apportées au programme.

//COMPILE   JOB ,CLASS = 6,MSGCLASS = X,NOTIFY = &SYSUID             
//*            
//STEP1     EXEC IGYCRCTL,PARM = RMODE,DYNAM,SSRANGE
//SYSIN     DD DSN = MYDATA.URMI.SOURCES(MYCOBB),DISP = SHR
//SYSLIB    DD DSN = MYDATA.URMI.COPYBOOK(MYCOPY),DISP = SHR
//SYSLMOD   DD DSN = MYDATA.URMI.LOAD(MYCOBB),DISP = SHR
//SYSPRINT  DD SYSOUT=*
//*

IGYCRCTL est un utilitaire de compilation IBM COBOL. Les options du compilateur sont transmises à l'aide du paramètre PARM. Dans l'exemple ci-dessus, RMODE indique au compilateur d'utiliser le mode d'adressage relatif dans le programme. Le programme COBOL est transmis à l'aide du paramètre SYSIN. Copybook est la bibliothèque utilisée par le programme dans SYSLIB.

Exécution de programmes COBOL

Vous trouverez ci-dessous un exemple JCL où le programme MYPROG est exécuté à l'aide du fichier d'entrée MYDATA.URMI.INPUT et produit deux fichiers de sortie écrits dans le spool.

//COBBSTEP  JOB CLASS = 6,NOTIFY = &SYSUID
//
//STEP10    EXEC PGM = MYPROG,PARM = ACCT5000
//STEPLIB   DD DSN = MYDATA.URMI.LOADLIB,DISP = SHR
//INPUT1    DD DSN = MYDATA.URMI.INPUT,DISP = SHR
//OUT1      DD SYSOUT=*
//OUT2      DD SYSOUT=*
//SYSIN     DD *
//CUST1     1000
//CUST2     1001
/*

Le module de chargement de MYPROG se trouve dans MYDATA.URMI.LOADLIB. Il est important de noter que le JCL ci-dessus ne peut être utilisé que pour un module COBOL non DB2.

Exécution de programmes COBOL-DB2

Pour exécuter un programme COBOL-DB2, un utilitaire IBM spécialisé est utilisé dans le JCL et le programme; La région DB2 et les paramètres requis sont transmis en entrée à l'utilitaire.

Les étapes suivies pour exécuter un programme COBOL-DB2 sont les suivantes:

  • Lors de la compilation d'un programme COBOL-DB2, un DBRM (Database Request Module) est créé avec le module de chargement. Le DBRM contient les instructions SQL des programmes COBOL dont la syntaxe a été vérifiée.

  • Le DBRM est lié à la région DB2 (environnement) dans laquelle le COBOL sera exécuté. Cela peut être fait à l'aide de l'utilitaire IKJEFT01 dans un JCL.

  • Après l'étape de liaison, le programme COBOL-DB2 est exécuté en utilisant IKJEFT01 (à nouveau) avec la bibliothèque de chargement et la bibliothèque DBRM en tant qu'entrée du JCL.

//STEP001  EXEC PGM = IKJEFT01
//*
//STEPLIB  DD DSN = MYDATA.URMI.DBRMLIB,DISP = SHR
//*
//input files
//output files
//SYSPRINT DD SYSOUT=*
//SYSABOUT DD SYSOUT=*
//SYSDBOUT DD SYSOUT=*
//SYSUDUMP DD SYSOUT=*
//DISPLAY  DD SYSOUT=*
//SYSOUT   DD SYSOUT=*
//SYSTSPRT DD SYSOUT=*
//SYSTSIN  DD *
   DSN SYSTEM(SSID)
   RUN PROGRAM(MYCOBB) PLAN(PLANNAME) PARM(parameters to cobol program) -
   LIB('MYDATA.URMI.LOADLIB')
   END
/*

Dans l'exemple ci-dessus, MYCOBB est le programme COBOL-DB2 exécuté à l'aide de IKJEFT01. Veuillez noter que le nom du programme, l'ID de sous-système DB2 (SSID) et le nom du plan DB2 sont transmis dans l'instruction SYSTSIN DD. La bibliothèque DBRM est spécifiée dans STEPLIB.

Une structure de programme COBOL se compose de divisions, comme indiqué dans l'image suivante -

Une brève introduction de ces divisions est donnée ci-dessous -

  • Sectionssont la subdivision logique de la logique du programme. Une section est un ensemble de paragraphes.

  • Paragraphssont la subdivision d'une section ou d'une division. Il s'agit d'un nom défini par l'utilisateur ou prédéfini suivi d'un point et se compose de zéro ou plusieurs phrases / entrées.

  • Sentencessont la combinaison d'une ou de plusieurs instructions. Les phrases n'apparaissent que dans la division Procédure. Une phrase doit se terminer par un point.

  • Statements sont des instructions COBOL significatives qui effectuent certains traitements.

  • Characters sont les plus bas de la hiérarchie et ne peuvent pas être divisibles.

Vous pouvez mettre en relation les termes mentionnés ci-dessus avec le programme COBOL dans l'exemple suivant -

PROCEDURE DIVISION.
A0000-FIRST-PARA SECTION.
FIRST-PARAGRAPH.
ACCEPT WS-ID            - Statement-1  -----|
MOVE '10' TO WS-ID      - Statement-2       |-- Sentence - 1
DISPLAY WS-ID           - Statement-3  -----|
.

Divisions

Un programme COBOL comprend quatre divisions.

Division d'identification

C'est la première et la seule division obligatoire de chaque programme COBOL. Le programmeur et le compilateur utilisent cette division pour identifier le programme. Dans cette division, PROGRAM-ID est le seul paragraphe obligatoire. PROGRAM-ID spécifie le nom du programme qui peut comprendre de 1 à 30 caractères.

Essayez l'exemple suivant en utilisant le Live Demo option en ligne.

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.
PROCEDURE DIVISION.
DISPLAY 'Welcome to Tutorialspoint'.
STOP RUN.

Ci-dessous est le JCL pour exécuter le programme COBOL ci-dessus.

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO

Lorsque vous compilez et exécutez le programme ci-dessus, il produit le résultat suivant -

Welcome to Tutorialspoint

Division de l'environnement

La division d'environnement est utilisée pour spécifier les fichiers d'entrée et de sortie du programme. Il se compose de deux sections -

  • Configuration sectionfournit des informations sur le système sur lequel le programme est écrit et exécuté. Il se compose de deux paragraphes -

    • Ordinateur source - Système utilisé pour compiler le programme.

    • Ordinateur objet - Système utilisé pour exécuter le programme.

  • Input-Output sectionfournit des informations sur les fichiers à utiliser dans le programme. Il se compose de deux paragraphes -

    • Contrôle de fichier - Fournit des informations sur les ensembles de données externes utilisés dans le programme.

    • Contrôle IO - Fournit des informations sur les fichiers utilisés dans le programme.

ENVIRONMENT DIVISION.
CONFIGURATION SECTION.
   SOURCE-COMPUTER. XXX-ZOS.
   OBJECT-COMPUTER. XXX-ZOS.

INPUT-OUTPUT SECTION.
   FILE-CONTROL.
   SELECT FILEN ASSIGN TO DDNAME
   ORGANIZATION IS SEQUENTIAL.

Division des données

La division des données est utilisée pour définir les variables utilisées dans le programme. Il se compose de quatre sections -

  • File section est utilisé pour définir la structure d'enregistrement du fichier.

  • Working-Storage section est utilisé pour déclarer des variables temporaires et des structures de fichiers qui sont utilisées dans le programme.

  • Local-Storage sectionest similaire à la section Working-Storage. La seule différence est que les variables seront allouées et initialisées chaque fois qu'un programme démarre l'exécution.

  • Linkage section est utilisé pour décrire les noms de données reçus d'un programme externe.

COBOL Program

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.

ENVIRONMENT DIVISION.
   INPUT-OUTPUT SECTION.
   FILE-CONTROL.
   SELECT FILEN ASSIGN TO INPUT.
      ORGANIZATION IS SEQUENTIAL.
      ACCESS IS SEQUENTIAL.

DATA DIVISION.
   FILE SECTION.
   FD FILEN
   01 NAME PIC A(25).
   
   WORKING-STORAGE SECTION.
   01 WS-STUDENT PIC A(30).
   01 WS-ID PIC 9(5).

   LOCAL-STORAGE SECTION.
   01 LS-CLASS PIC 9(3).
   
   LINKAGE SECTION.
   01 LS-ID PIC 9(5).
   
PROCEDURE DIVISION.
   DISPLAY 'Executing COBOL program using JCL'.
STOP RUN.

le JCL pour exécuter le programme COBOL ci-dessus est comme suit -

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO
//INPUT DD DSN = ABC.EFG.XYZ,DISP = SHR

Lorsque vous compilez et exécutez le programme ci-dessus, il produit le résultat suivant -

Executing COBOL program using JCL

Division de la procédure

La division de procédure est utilisée pour inclure la logique du programme. Il se compose d'instructions exécutables utilisant des variables définies dans la division des données. Dans cette division, les noms de paragraphe et de section sont définis par l'utilisateur.

Il doit y avoir au moins une déclaration dans la division de procédure. La dernière instruction pour terminer l'exécution dans cette division est soitSTOP RUN qui est utilisé dans les programmes d'appel ou EXIT PROGRAM qui est utilisé dans les programmes appelés.

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.

DATA DIVISION.
   WORKING-STORAGE SECTION.
   01 WS-NAME PIC A(30).
   01 WS-ID PIC 9(5) VALUE 12345.

PROCEDURE DIVISION.
   A000-FIRST-PARA.
   DISPLAY 'Hello World'.
   MOVE 'TutorialsPoint' TO WS-NAME.
   DISPLAY "My name is : "WS-NAME.
   DISPLAY "My ID is : "WS-ID.
STOP RUN.

JCL pour exécuter le programme COBOL ci-dessus -

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO

Lorsque vous compilez et exécutez le programme ci-dessus, il produit le résultat suivant -

Hello World
My name is : TutorialsPoint
My ID is : 12345

Jeu de caractères

Les «caractères» sont les plus bas de la hiérarchie et ils ne peuvent pas être divisés davantage. Le jeu de caractères COBOL comprend 78 caractères qui sont indiqués ci-dessous -

Sr.No. Caractère et description
1

A-Z

Alphabets (majuscules)

2

a-z

Alphabets (minuscules)

3

0-9

Numérique

4

 

Espace

5

+

Signe plus

6

-

Signe moins ou trait d'union

sept

*

Astérisque

8

/

Barre oblique avant

9

$

Signe de devise

dix

,

Virgule

11

;

Point virgule

12

.

Point décimal ou période

13

"

Guillemets

14

(

Parenthèse gauche

15

)

Parenthèse droite

16

>

Plus grand que

17

<

Moins que

18

:

Côlon

19

'

Apostrophe

20

=

Signe égal

Fiche de codage

Le programme source de COBOL doit être écrit dans un format acceptable pour les compilateurs. Les programmes COBOL sont écrits sur des feuilles de codage COBOL. Il y a 80 positions de caractères sur chaque ligne d'une feuille de codage.

Les positions des caractères sont regroupées dans les cinq champs suivants -

Positions Champ La description
1-6 Numéros de colonne Réservé aux numéros de ligne.
sept Indicateur Il peut avoir un astérisque (*) indiquant des commentaires, un trait d'union (-) indiquant la suite et une barre oblique (/) indiquant un saut de page.
8-11 Zone A Toutes les divisions, sections, paragraphes et certaines entrées spéciales COBOL doivent commencer dans la zone A.
12-72 Zone B Toutes les instructions COBOL doivent commencer dans la zone B.
73-80 Zone d'identification Il peut être utilisé selon les besoins par le programmeur.

Exemple

L'exemple suivant montre une feuille de codage COBOL -

000100 IDENTIFICATION DIVISION.                                         000100
000200 PROGRAM-ID. HELLO.                                               000101
000250* THIS IS A COMMENT LINE                                          000102
000300 PROCEDURE DIVISION.                                              000103
000350 A000-FIRST-PARA.                                                 000104
000400     DISPLAY “Coding Sheet”.                                      000105
000500 STOP RUN.                                                        000106

JCL pour exécuter le programme COBOL ci-dessus -

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO

Lorsque vous compilez et exécutez le programme ci-dessus, il produit le résultat suivant -

Coding Sheet

Chaînes de caractères

Les chaînes de caractères sont formées en combinant des caractères individuels. Une chaîne de caractères peut être un

  • Comment,
  • Littéral, ou
  • Mot COBOL.

Toutes les chaînes de caractères doivent se terminer par separators. Un séparateur est utilisé pour séparer les chaînes de caractères.

Séparateurs fréquemment utilisés: espace, virgule, point, apostrophe, parenthèses gauche / droite et guillemet.

Commentaire

Un commentaire est une chaîne de caractères qui n'affecte pas l'exécution d'un programme. Cela peut être n'importe quelle combinaison de caractères.

Il existe deux types de commentaires -

Ligne de commentaire

Une ligne de commentaire peut être écrite dans n'importe quelle colonne. Le compilateur ne vérifie pas la syntaxe d'une ligne de commentaire et la traite pour la documentation.

Entrée de commentaire

Les entrées de commentaires sont celles qui sont incluses dans les paragraphes facultatifs d'une division d'identification. Ils sont écrits dans la zone B et les programmeurs l'utilisent comme référence.

Le texte mis en évidence dans Bold sont les entrées commentées dans l'exemple suivant -

000100 IDENTIFICATION DIVISION.                                         000100
000150 PROGRAM-ID. HELLO.                                               000101 
000200 AUTHOR. TUTORIALSPOINT.                                          000102
000250* THIS IS A COMMENT LINE                                          000103
000300 PROCEDURE DIVISION.                                              000104
000350 A000-FIRST-PARA.                                                 000105  
000360/ First Para Begins - Documentation Purpose                       000106
000400     DISPLAY “Comment line”.                                      000107
000500 STOP RUN.                                                        000108

JCL pour exécuter le programme COBOL ci-dessus -

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO

Lorsque vous compilez et exécutez le programme ci-dessus, il produit le résultat suivant -

Comment Line

Littéral

Le littéral est une constante directement codée en dur dans un programme. Dans l'exemple suivant, «Hello World» est un littéral.

PROCEDURE DIVISION.
DISPLAY 'Hello World'.

Il existe deux types de littéraux comme indiqué ci-dessous -

Littéral alphanumérique

Les littéraux alphanumériques sont placés entre guillemets ou apostrophe. La longueur peut aller jusqu'à 160 caractères. Une apostrophe ou une citation ne peut faire partie d'un littéral que si elle est associée. Le début et la fin du littéral doivent être identiques, soit une apostrophe, soit une citation.

Example

L'exemple suivant montre des littéraux alphanumériques valides et non valides -

Valid:
   ‘This is valid’
   "This is valid"
   ‘This isn’’t invalid’

Invalid:
   ‘This is invalid”
   ‘This isn’t valid’

Littéral numérique

Un littéral numérique est une combinaison de chiffres de 0 à 9, +, - ou un point décimal. La longueur peut comporter jusqu'à 18 caractères. Le signe ne peut pas être le caractère le plus à droite. Le point décimal ne doit pas apparaître à la fin.

Example

L'exemple suivant montre des littéraux numériques valides et non valides -

Valid:
   100
   +10.9
   -1.9

Invalid:
   1,00
   10.
   10.9-

Mot COBOL

COBOL Word est une chaîne de caractères qui peut être un mot réservé ou un mot défini par l'utilisateur. La longueur peut comporter jusqu'à 30 caractères.

Défini par l'utilisateur

Les mots définis par l'utilisateur sont utilisés pour nommer les fichiers, les données, les enregistrements, les noms de paragraphes et les sections. Les alphabets, chiffres et traits d'union sont autorisés lors de la formation de mots définis par l'utilisateur. Vous ne pouvez pas utiliser de mots réservés COBOL.

Mots réservés

Les mots réservés sont des mots prédéfinis en COBOL. Les différents types de mots réservés que nous utilisons fréquemment sont les suivants -

  • Keywords comme AJOUTER, ACCEPTER, DÉPLACER, etc.

  • Special characters des mots comme +, -, *, <, <=, etc.

  • Figurative constants sont des valeurs constantes comme ZERO, SPACES, etc. Toutes les valeurs constantes des constantes figuratives sont mentionnées dans le tableau suivant.

Constantes figuratives

Sr.No. Figurative Constants & Description
1

HIGH-VALUES

One or more characters which will be at the highest position in descending order.

2

LOW-VALUES

One or more characters have zeros in binary representation.

3

ZERO/ZEROES

One or more zero depending on the size of the variable.

4

SPACES

One or more spaces.

5

QUOTES

Single or double quotes.

6

ALL literal

Fills the data-item with Literal.

Data Division is used to define the variables used in a program. To describe data in COBOL, one must understand the following terms −

  • Data Name
  • Level Number
  • Picture Clause
  • Value Clause
01            TOTAL-STUDENTS            PIC9(5)            VALUE '125'.
|                    |                    |                    |
|                    |                    |                    |
|                    |                    |                    | 
Level Number     Data Name           Picture Clause       Value Clause

Data Name

Data names must be defined in the Data Division before using them in the Procedure Division. They must have a user-defined name; reserved words cannot be used. Data names give reference to the memory locations where actual data is stored. They can be elementary or group type.

Example

The following example shows valid and invalid data names −

Valid:
   WS-NAME
   TOTAL-STUDENTS
   A100
   100B

Invalid:
   MOVE            (Reserved Words)
   COMPUTE         (Reserved Words)
   100             (No Alphabet)
   100+B           (+ is not allowed)

Level Number

Level number is used to specify the level of data in a record. They are used to differentiate between elementary items and group items. Elementary items can be grouped together to create group items.

Sr.No. Level Number & Description
1

01

Record description entry

2

02 to 49

Group and Elementary items

3

66

Rename Clause items

4

77

Items which cannot be sub-divided

5

88

Condition name entry

  • Elementary items cannot be divided further. Level number, Data name, Picture clause, and Value clause (optional) are used to describe an elementary item.

  • Group items consist of one or more elementary items. Level number, Data name, and Value clause (optional) are used to describe a group item. Group level number is always 01.

Example

The following example shows Group and Elementary items −

DATA DIVISION.
WORKING-STORAGE SECTION.
01 WS-NAME    PIC X(25).                               ---> ELEMENTARY ITEM 
01 WS-CLASS   PIC 9(2)  VALUE  '10'.                   ---> ELEMENTARY ITEM

01 WS-ADDRESS.                                         ---> GROUP ITEM   
   05 WS-HOUSE-NUMBER    PIC 9(3).                     ---> ELEMENTARY ITEM
   05 WS-STREET          PIC X(15).                    ---> ELEMENTARY ITEM
   05 WS-CITY            PIC X(15).                    ---> ELEMENTARY ITEM
   05 WS-COUNTRY         PIC X(15)  VALUE 'INDIA'.     ---> ELEMENTARY ITEM

Picture Clause

Picture clause is used to define the following items −

  • Data type can be numeric, alphabetic, or alphanumeric. Numeric type consists of only digits 0 to 9. Alphabetic type consists of letters A to Z and spaces. Alphanumeric type consists of digits, letters, and special characters.

  • Sign can be used with numeric data. It can be either + or –.

  • Decimal point position can be used with numeric data. Assumed position is the position of decimal point and not included in the data.

  • Length defines the number of bytes used by the data item.

Symbols used in a Picture clause −

Sr.No. Symbol & Description
1

9

Numeric

2

A

Alphabetic

3

X

Alphanumeric

4

V

Implicit Decimal

5

S

Sign

6

P

Assumed Decimal

Example

The following example shows the use of PIC clause −

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.

DATA DIVISION.
   WORKING-STORAGE SECTION.
   01 WS-NUM1 PIC S9(3)V9(2).
   01 WS-NUM2 PIC PPP999.
   01 WS-NUM3 PIC S9(3)V9(2) VALUE -123.45.
   01 WS-NAME PIC A(6) VALUE 'ABCDEF'.
   01 WS-ID PIC X(5) VALUE 'A121$'.

PROCEDURE DIVISION.
   DISPLAY "WS-NUM1 : "WS-NUM1.
   DISPLAY "WS-NUM2 : "WS-NUM2.
   DISPLAY "WS-NUM3 : "WS-NUM3.
   DISPLAY "WS-NAME : "WS-NAME.
   DISPLAY "WS-ID : "WS-ID.
STOP RUN.

JCL to execute the above COBOL program −

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO

When you compile and execute the above program, it produces the following result −

WS-NUM1 : +000.00
WS-NUM2 : .000000
WS-NUM3 : -123.45
WS-NAME : ABCDEF
WS-ID : A121$

Value Clause

Value clause is an optional clause which is used to initialize the data items. The values can be numeric literal, alphanumeric literal, or figurative constant. It can be used with both group and elementary items.

Example

The following example shows the use of VALUE clause −

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.

DATA DIVISION.
   WORKING-STORAGE SECTION.
   01 WS-NUM1 PIC 99V9 VALUE IS 3.5.
   01 WS-NAME PIC A(6) VALUE 'ABCD'.
   01 WS-ID PIC 99 VALUE ZERO.

PROCEDURE DIVISION.
   DISPLAY "WS-NUM1 : "WS-NUM1.
   DISPLAY "WS-NAME : "WS-NAME.
   DISPLAY "WS-ID   : "WS-ID.
STOP RUN.

JCL to execute the above COBOL program −

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO

When you compile and execute the above program, it produces the following result −

WS-NUM1 : 03.5
WS-NAME : ABCD
WS-ID   : 00

COBOL verbs are used in the procedure division for data processing. A statement always start with a COBOL verb. There are several COBOL verbs with different types of actions.

Input / Output Verbs

Input/Output verbs are used to get data from the user and display the output of COBOL programs. The following two verbs are used for this process −

Accept Verb

Accept verb is used to get data such as date, time, and day from the operating system or directly from the user. If a program is accepting data from the user, then it needs to be passed through JCL. While getting data from the operating system, FROM option is included as shown in the following example −

ACCEPT WS-STUDENT-NAME.
ACCEPT WS-DATE FROM SYSTEM-DATE.

Display Verb

Display verb is used to display the output of a COBOL program.

DISPLAY WS-STUDENT-NAME.
DISPLAY "System date is : " WS-DATE.

COBOL PROGRAM

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.

DATA DIVISION.
   WORKING-STORAGE SECTION.
   01 WS-STUDENT-NAME PIC X(25).
   01 WS-DATE PIC X(10).

PROCEDURE DIVISION.
   ACCEPT WS-STUDENT-NAME.
   ACCEPT WS-DATE FROM DATE.
   DISPLAY "Name :  " WS-STUDENT-NAME.
   DISPLAY "Date : " WS-DATE.

STOP RUN.

JCL to execute the above COBOL program −

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO
//INPUT DD DSN=PROGRAM.DIRECTORY,DISP=SHR
//SYSIN DD *
TutorialsPoint
/*

When you compile and execute the above program, it produces the following result −

Name : TutorialsPoint
Date : 200623

Initialize Verb

Initialize verb is used to initialize a group item or an elementary item. Data names with RENAME clause cannot be initialized. Numeric data items are replaced by ZEROES. Alphanumeric or alphabetic data items are replaced by SPACES. If we include REPLACING term, then data items can be initialized to the given replacing value as shown in the following example −

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.

DATA DIVISION.
   WORKING-STORAGE SECTION.
   01 WS-NAME PIC A(30) VALUE 'ABCDEF'.
   01 WS-ID PIC 9(5).
   01 WS-ADDRESS. 
   05 WS-HOUSE-NUMBER PIC 9(3).
   05 WS-COUNTRY PIC X(15).
   05 WS-PINCODE PIC 9(6) VALUE 123456.

PROCEDURE DIVISION.
   A000-FIRST-PARA.
   INITIALIZE WS-NAME, WS-ADDRESS.
   INITIALIZE WS-ID REPLACING NUMERIC DATA BY 12345.
   DISPLAY "My name is   : "WS-NAME.
   DISPLAY "My ID is     : "WS-ID.
   DISPLAY "Address      : "WS-ADDRESS.
   DISPLAY "House Number : "WS-HOUSE-NUMBER.
   DISPLAY "Country      : "WS-COUNTRY.
   DISPLAY "Pincode      : "WS-PINCODE.

STOP RUN.

JCL to execute the above COBOL program −

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO

When you compile and execute the above program, it produces the following result −

My name is   :                               
My ID is     : 12345
Address      : 000               000000
House Number : 000
Country      :                
Pincode      : 000000

Move Verb

Move verb is used to copy data from source data to destination data. It can be used on both elementary and group data items. For group data items, MOVE CORRESPONDING/CORR is used. In try it option, MOVE CORR is not working; but on a mainframe server, it will work.

For moving data from a string, MOVE(x:l) is used where x is the starting position and l is the length. Data will be truncated if the destination data item PIC clause is less than the source data item PIC clause. If the destination data item PIC clause is more than the source data item PIC clause, then ZEROS or SPACES will be added in the extra bytes. The following example makes it clear.

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.

DATA DIVISION.
   WORKING-STORAGE SECTION.
   01 WS-NUM1 PIC 9(9).
   01 WS-NUM2 PIC 9(9).
   01 WS-NUM3 PIC 9(5).
   01 WS-NUM4 PIC 9(6).
   01 WS-ADDRESS. 
   05 WS-HOUSE-NUMBER PIC 9(3).
   05 WS-COUNTRY PIC X(5).
   05 WS-PINCODE PIC 9(6).
   01 WS-ADDRESS1. 
   05 WS-HOUSE-NUMBER1 PIC 9(3).
   05 WS-COUNTRY1 PIC X(5).
   05 WS-PINCODE1 PIC 9(6).

PROCEDURE DIVISION.
   A000-FIRST-PARA.
   MOVE 123456789 TO WS-NUM1.
   MOVE WS-NUM1 TO WS-NUM2 WS-NUM3.
   MOVE WS-NUM1(3:6) TO WS-NUM4.
   MOVE 123 TO WS-HOUSE-NUMBER.
   MOVE 'INDIA' TO WS-COUNTRY.
   MOVE 112233 TO WS-PINCODE.
   MOVE WS-ADDRESS TO WS-ADDRESS1.

   DISPLAY "WS-NUM1     : " WS-NUM1
   DISPLAY "WS-NUM2     : " WS-NUM2
   DISPLAY "WS-NUM3     : " WS-NUM3
   DISPLAY "WS-NUM4     : " WS-NUM4
   DISPLAY "WS-ADDRESS  : " WS-ADDRESS
   DISPLAY "WS-ADDRESS1 : " WS-ADDRESS1

STOP RUN.

JCL to execute the above COBOL program.

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO

When you compile and execute the above program, it produces the following result −

WS-NUM1     : 123456789
WS-NUM2     : 123456789
WS-NUM3     : 56789
WS-NUM4     : 345678
WS-ADDRESS  : 123INDIA112233
WS-ADDRESS1 : 123INDIA112233

Legal Moves

The following table gives information about the legal moves −

Alphabetic Alphanumeric Numeric
Alphabetic Possible Possible Not Possible
Alphanumeric Possible Possible Possible
Numeric Not Possible Possible Possible

Add Verb

Add verb is used to add two or more numbers and store the result in the destination operand.

Syntax

Given below is the syntax to Add two or more numbers −

ADD A B TO C D

ADD A B C TO D GIVING E

ADD CORR WS-GROUP1 TO WS-GROUP2

In syntax-1, A, B, C are added and the result is stored in C (C=A+B+C). A, B, D are added and the result is stored in D (D = A + B + D).

In syntax-2, A, B, C, D are added and the result is stored in E (E=A+B+C+D).

In syntax-3, sub-group items within WS-GROUP1 and WS-GROUP2 are added and the result is stored in WS-GROUP2.

Example

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.

DATA DIVISION.
   WORKING-STORAGE SECTION.
   01 WS-NUM1 PIC 9(9) VALUE 10 .
   01 WS-NUM2 PIC 9(9) VALUE 10.
   01 WS-NUM3 PIC 9(9) VALUE 10.
   01 WS-NUM4 PIC 9(9) VALUE 10.
   01 WS-NUMA PIC 9(9) VALUE 10.
   01 WS-NUMB PIC 9(9) VALUE 10.
   01 WS-NUMC PIC 9(9) VALUE 10.
   01 WS-NUMD PIC 9(9) VALUE 10.
   01 WS-NUME PIC 9(9) VALUE 10.

PROCEDURE DIVISION.
   ADD WS-NUM1 WS-NUM2 TO WS-NUM3 WS-NUM4.
   ADD WS-NUMA WS-NUMB WS-NUMC TO WS-NUMD GIVING WS-NUME.
   DISPLAY "WS-NUM1     : " WS-NUM1
   DISPLAY "WS-NUM2     : " WS-NUM2
   DISPLAY "WS-NUM3     : " WS-NUM3
   DISPLAY "WS-NUM4     : " WS-NUM4
   DISPLAY "WS-NUMA     : " WS-NUMA
   DISPLAY "WS-NUMB     : " WS-NUMB
   DISPLAY "WS-NUMC     : " WS-NUMC
   DISPLAY "WS-NUMD     : " WS-NUMD
   DISPLAY "WS-NUME     : " WS-NUME

STOP RUN.

JCL to execute the above COBOL program −

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO

When you compile and execute the above program, it produces the following result −

WS-NUM1     : 000000010
WS-NUM2     : 000000010
WS-NUM3     : 000000030
WS-NUM4     : 000000030
WS-NUMA     : 000000010
WS-NUMB     : 000000010
WS-NUMC     : 000000010
WS-NUMD     : 000000010
WS-NUME     : 000000040

Subtract Verb

Subtract verb is used for subtraction operations.

Syntax

Given below is the syntax for Subtract operations −

SUBTRACT A B FROM C D

SUBTRACT A B C FROM D GIVING E

SUBTRACT CORR WS-GROUP1 TO WS-GROUP2

In syntax-1, A and B are added and subtracted from C. The result is stored in C (C = C-(A+B)). A and B are added and subtracted from D. The result is stored in D (D = D-(A+B)).

In syntax-2, A, B, C are added and subtracted from D. The result is stored in E (E = D-(A+B+C))

In syntax-3, sub-group items within WS-GROUP1 and WS-GROUP2 are subtracted and the result is stored in WS-GROUP2.

Example

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.

DATA DIVISION.
   WORKING-STORAGE SECTION.
   01 WS-NUM1 PIC 9(9) VALUE 10 .
   01 WS-NUM2 PIC 9(9) VALUE 10.
   01 WS-NUM3 PIC 9(9) VALUE 100.
   01 WS-NUM4 PIC 9(9) VALUE 100.
   01 WS-NUMA PIC 9(9) VALUE 10.
   01 WS-NUMB PIC 9(9) VALUE 10.
   01 WS-NUMC PIC 9(9) VALUE 10.
   01 WS-NUMD PIC 9(9) VALUE 100.
   01 WS-NUME PIC 9(9) VALUE 10.

PROCEDURE DIVISION.
   SUBTRACT WS-NUM1 WS-NUM2 FROM WS-NUM3 WS-NUM4.
   SUBTRACT WS-NUMA WS-NUMB WS-NUMC FROM WS-NUMD GIVING WS-NUME.

   DISPLAY "WS-NUM1     : " WS-NUM1
   DISPLAY "WS-NUM2     : " WS-NUM2
   DISPLAY "WS-NUM3     : " WS-NUM3
   DISPLAY "WS-NUM4     : " WS-NUM4
   DISPLAY "WS-NUMA     : " WS-NUMA
   DISPLAY "WS-NUMB     : " WS-NUMB
   DISPLAY "WS-NUMC     : " WS-NUMC
   DISPLAY "WS-NUMD     : " WS-NUMD
   DISPLAY "WS-NUME     : " WS-NUME

STOP RUN.

JCL to execute the above COBOL program −

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO

When you compile and execute the above program, it produces the following result −

WS-NUM1     : 000000010
WS-NUM2     : 000000010
WS-NUM3     : 000000080
WS-NUM4     : 000000080
WS-NUMA     : 000000010
WS-NUMB     : 000000010
WS-NUMC     : 000000010
WS-NUMD     : 000000100
WS-NUME     : 000000070

Multiply Verb

Multiply verb is used for multiplication operations.

Syntax

Given below is the syntax to multiply two or more numbers −

MULTIPLY A BY B C

MULTIPLY A BY B GIVING E

In syntax-1, A and B are multipled and the result is stored in B (B=A*B). A and C are multipled and the result is stored in C (C = A * C).

In syntax-2, A and B are multipled and the result is stored in E (E=A*B).

Example

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.

DATA DIVISION.
   WORKING-STORAGE SECTION.
   01 WS-NUM1 PIC 9(9) VALUE 10 .
   01 WS-NUM2 PIC 9(9) VALUE 10.
   01 WS-NUM3 PIC 9(9) VALUE 10.
   01 WS-NUMA PIC 9(9) VALUE 10.
   01 WS-NUMB PIC 9(9) VALUE 10.
   01 WS-NUMC PIC 9(9) VALUE 10.

PROCEDURE DIVISION.
   MULTIPLY WS-NUM1 BY WS-NUM2 WS-NUM3.
   MULTIPLY WS-NUMA BY WS-NUMB GIVING WS-NUMC.
   
   DISPLAY "WS-NUM1     : " WS-NUM1
   DISPLAY "WS-NUM2     : " WS-NUM2
   DISPLAY "WS-NUM3     : " WS-NUM3
   DISPLAY "WS-NUMA     : " WS-NUMA
   DISPLAY "WS-NUMB     : " WS-NUMB
   DISPLAY "WS-NUMC     : " WS-NUMC
   
STOP RUN.

JCL to execute the above COBOL program −

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO

When you compile and execute the above program, it produces the following result −

WS-NUM1     : 000000010
WS-NUM2     : 000000100
WS-NUM3     : 000000100
WS-NUMA     : 000000010
WS-NUMB     : 000000010
WS-NUMC     : 000000100

Divide Verb

Divide verb is used for division operations.

Syntax

Given below is the syntax for division operations −

DIVIDE A INTO B

DIVIDE A BY B GIVING C REMAINDER R

In syntax-1, B is divided by A and the result is stored in B (B=B/A).

In syntax-2, A is divided by B and the result is stored in C (C=A/B) and the remainder is stored in R.

Example

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.

DATA DIVISION.
   WORKING-STORAGE SECTION.
   01 WS-NUM1 PIC 9(9) VALUE 5.
   01 WS-NUM2 PIC 9(9) VALUE 250.
   01 WS-NUMA PIC 9(9) VALUE 100.
   01 WS-NUMB PIC 9(9) VALUE 15.
   01 WS-NUMC PIC 9(9).
   01 WS-REM PIC 9(9). 

PROCEDURE DIVISION.
   DIVIDE WS-NUM1 INTO WS-NUM2.
   DIVIDE WS-NUMA BY WS-NUMB GIVING WS-NUMC REMAINDER WS-REM.
   DISPLAY "WS-NUM1     : " WS-NUM1
   DISPLAY "WS-NUM2     : " WS-NUM2
   DISPLAY "WS-NUMA     : " WS-NUMA
   DISPLAY "WS-NUMB     : " WS-NUMB
   DISPLAY "WS-NUMC     : " WS-NUMC
   DISPLAY "WS-REM      : " WS-REM
   
STOP RUN.

JCL to execute the above COBOL program −

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO

When you compile and execute the above program, it produces the following result −

WS-NUM1     : 000000005
WS-NUM2     : 000000050
WS-NUMA     : 000000100
WS-NUMB     : 000000015
WS-NUMC     : 000000006
WS-REM      : 000000010

Compute Statement

Compute statement is used to write arithmetic expressions in COBOL. This is a replacement for Add, Subtract, Multiply, and Divide.

Example

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.

DATA DIVISION.
   WORKING-STORAGE SECTION.
   01 WS-NUM1 PIC 9(9) VALUE 10 .
   01 WS-NUM2 PIC 9(9) VALUE 10.
   01 WS-NUM3 PIC 9(9) VALUE 10.
   01 WS-NUMA PIC 9(9) VALUE 50.
   01 WS-NUMB PIC 9(9) VALUE 10.
   01 WS-NUMC PIC 9(9).

PROCEDURE DIVISION.
   COMPUTE WS-NUMC= (WS-NUM1 * WS-NUM2) - (WS-NUMA / WS-NUMB) + WS-NUM3.
   DISPLAY "WS-NUM1     : " WS-NUM1
   DISPLAY "WS-NUM2     : " WS-NUM2
   DISPLAY "WS-NUM3     : " WS-NUM3
   DISPLAY "WS-NUMA     : " WS-NUMA
   DISPLAY "WS-NUMB     : " WS-NUMB
   DISPLAY "WS-NUMC     : " WS-NUMC

STOP RUN.

JCL to execute the above COBOL program.

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO

When you compile and execute the above program, it produces the following result −

WS-NUM1     : 000000010
WS-NUM2     : 000000010
WS-NUM3     : 000000010
WS-NUMA     : 000000050
WS-NUMB     : 000000010
WS-NUMC     : 000000105

COBOL layout is the description of use of each field and the values present in it. Following are the data description entries used in COBOL −

  • Redefines Clause
  • Renames Clause
  • Usage Clause
  • Copybooks

Redefines Clause

Redefines clause is used to define a storage with different data description. If one or more data items are not used simultaneously, then the same storage can be utilized for another data item. So the same storage can be referred with different data items.

Syntax

Following is the syntax for Redefines clause −

01 WS-OLD PIC X(10).
01 WS-NEW1 REDEFINES WS-OLD PIC 9(8).
01 WS-NEW2 REDEFINES WS-OLD PIC A(10).

Following are the details of the used parameters −

  • WS-OLD is Redefined Item
  • WS-NEW1 and WS-NEW2 are Redefining Item

Level numbers of redefined item and redefining item must be the same and it cannot be 66 or 88 level number. Do not use VALUE clause with a redefining item. In File Section, do not use a redefines clause with 01 level number. Redefines definition must be the next data description you want to redefine. A redefining item will always have the same value as a redefined item.

Example

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.

DATA DIVISION.
   WORKING-STORAGE SECTION.
   01 WS-DESCRIPTION.
   05 WS-DATE1 VALUE '20140831'.
   10 WS-YEAR PIC X(4).
   10 WS-MONTH PIC X(2).
   10 WS-DATE PIC X(2).
   05 WS-DATE2 REDEFINES WS-DATE1 PIC 9(8).

PROCEDURE DIVISION.
   DISPLAY "WS-DATE1 : "WS-DATE1.
   DISPLAY "WS-DATE2 : "WS-DATE2.

STOP RUN.

JCL to execute the above COBOL program −

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO

When you compile and execute the above program it produces the following result −

WS-DATE1 : 20140831
WS-DATE2 : 20140831

Renames Clause

Renames clause is used to give different names to existing data items. It is used to re-group the data names and give a new name to them. The new data names can rename across groups or elementary items. Level number 66 is reserved for renames.

Syntax

Following is the syntax for Renames clause −

01 WS-OLD.
10 WS-A PIC 9(12).
10 WS-B PIC X(20).
10 WS-C PIC A(25).
10 WS-D PIC X(12).
66 WS-NEW RENAMES WS-A THRU WS-C.

Renaming is possible at same level only. In the above example, WS-A, WS-B, and WS-C are at the same level. Renames definition must be the next data description you want to rename. Do not use Renames with 01, 77, or 66 level number. The data names used for renames must come in sequence. Data items with occur clause cannot be renamed.

Example

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.

DATA DIVISION.
   WORKING-STORAGE SECTION.
   01 WS-DESCRIPTION.
   05 WS-NUM.
   10 WS-NUM1 PIC 9(2) VALUE 20.
   10 WS-NUM2 PIC 9(2) VALUE 56.
   05 WS-CHAR.
   10 WS-CHAR1 PIC X(2) VALUE 'AA'.
   10 WS-CHAR2 PIC X(2) VALUE 'BB'.
   66 WS-RENAME RENAMES WS-NUM2 THRU WS-CHAR2.

PROCEDURE DIVISION.
   DISPLAY "WS-RENAME : " WS-RENAME.
   
STOP RUN.

JCL to execute the above COBOL program −

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO

When you compile and execute the above program, it produces the following result −

WS-RENAME : 56AABB

Usage Clause

Usage clause specifies the operating system in which the format data is stored. It cannot be used with level numbers 66 or 88. If usage clause is specified on a group, then all the elementary items will have the same usage clause. The different options available with Usage clause are as follows −

Display

Data item is stored in ASCII format and each character will take 1 byte. It is default usage.

The following example calculates the number of bytes required −

01 WS-NUM PIC S9(5)V9(3) USAGE IS DISPLAY.
It requires 8 bytes as sign and decimal doesn't require any byte.

01 WS-NUM PIC 9(5) USAGE IS DISPLAY.
It requires 5 bytes as sign.

COMPUTATIONAL / COMP

Data item is stored in binary format. Here, data items must be integer.

The following example calculates the number of bytes required −

01 WS-NUM PIC S9(n) USAGE IS COMP.

If 'n' = 1 to 4, it takes 2 bytes.
If 'n' = 5 to 9, it takes 4 bytes.
If 'n' = 10 to 18, it takes 8 bytes.

COMP-1

L'élément de données est similaire à Real ou Float et est représenté sous la forme d'un nombre à virgule flottante simple précision. En interne, les données sont stockées au format hexadécimal. COMP-1 n'accepte pas la clause PIC. Ici, 1 mot est égal à 4 octets.

COMP-2

L'élément de données est similaire à Long ou Double et est représenté sous forme de nombre à virgule flottante double précision. En interne, les données sont stockées au format hexadécimal. COMP-2 ne spécifie pas la clause PIC. Ici, 2 mots sont égaux à 8 octets.

COMP-3

L'élément de données est stocké au format décimal compressé. Chaque chiffre occupe un demi-octet (1 quartet) et le signe est stocké dans le quartet le plus à droite.

L'exemple suivant calcule le nombre d'octets requis -

01 WS-NUM PIC 9(n) USAGE IS COMP.
Number of bytes = n/2 (If n is even)
Number of bytes = n/2 + 1(If n is odd, consider only integer part)

01 WS-NUM PIC 9(4) USAGE IS COMP-3 VALUE 21.
It requires 2 bytes of storage as each digit occupies half a byte.

01 WS-NUM PIC 9(5) USAGE IS COMP-3 VALUE 21.
It requires 3 bytes of storage as each digit occupies half a byte.

Cahiers

Un copybook COBOL est une sélection de code qui définit les structures de données. Si une structure de données particulière est utilisée dans de nombreux programmes, au lieu de réécrire la même structure de données, nous pouvons utiliser des cahiers. Nous utilisons l'instruction COPY pour inclure un cahier dans un programme. L'instruction COPY est utilisée dans la section WorkingStorage.

L'exemple suivant inclut un cahier dans un programme COBOL -

DATA DIVISION.
WORKING-STORAGE SECTION.
COPY ABC.

Ici ABC est le nom du cahier. Les éléments de données suivants dans le cahier ABC peuvent être utilisés dans un programme.

01 WS-DESCRIPTION.
   05 WS-NUM.
      10 WS-NUM1 PIC 9(2) VALUE 20.
      10 WS-NUM2 PIC 9(2) VALUE 56.
   05 WS-CHAR.
      10 WS-CHAR1 PIC X(2) VALUE 'AA'.
      10 WS-CHAR2 PIC X(2) VALUE 'BB'.

Les instructions conditionnelles sont utilisées pour modifier le flux d'exécution en fonction de certaines conditions spécifiées par le programmeur. Les instructions conditionnelles seront toujours évaluées à vrai ou faux. Les conditions sont utilisées dans les instructions IF, Evaluate et Perform. Les différents types de conditions sont les suivants -

  • Instruction de condition IF
  • Condition de relation
  • État du signe
  • Condition de classe
  • Condition-Nom Condition
  • Condition annulée
  • Condition combinée

Instruction de condition IF

L'instruction IF vérifie les conditions. Si une condition est vraie, le bloc IF est exécuté; et si la condition est fausse, le bloc ELSE est exécuté.

END-IFest utilisé pour terminer le bloc IF. Pour terminer le bloc IF, une période peut être utilisée à la place de END-IF. Mais il est toujours préférable d'utiliser END-IF pour plusieurs blocs IF.

Nested-IF- Blocs IF apparaissant dans un autre bloc IF. Il n'y a pas de limite à la profondeur des instructions IF imbriquées.

Syntaxe

Voici la syntaxe des instructions de condition IF -

IF [condition] THEN
   [COBOL statements]
ELSE
   [COBOL statements]
END-IF.

Example

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.

DATA DIVISION.
   WORKING-STORAGE SECTION.
   01 WS-NUM1 PIC 9(9).
   01 WS-NUM2 PIC 9(9).
   01 WS-NUM3 PIC 9(5).
   01 WS-NUM4 PIC 9(6).

PROCEDURE DIVISION.
   A000-FIRST-PARA.
   MOVE 25 TO WS-NUM1 WS-NUM3.
   MOVE 15 TO WS-NUM2 WS-NUM4.
   
   IF WS-NUM1 > WS-NUM2 THEN
      DISPLAY 'IN LOOP 1 - IF BLOCK'
      
      IF WS-NUM3 = WS-NUM4 THEN
         DISPLAY 'IN LOOP 2 - IF BLOCK'
      ELSE
         DISPLAY 'IN LOOP 2 - ELSE BLOCK'
      END-IF
      
   ELSE
      DISPLAY 'IN LOOP 1 - ELSE BLOCK'
   END-IF.
   
STOP RUN.

JCL pour exécuter le programme COBOL ci-dessus -

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO

Lorsque vous compilez et exécutez le programme ci-dessus, il produit le résultat suivant -

IN LOOP 1 - IF BLOCK
IN LOOP 2 - ELSE BLOCK

Condition de relation

La condition de relation compare deux opérandes, dont l'un peut être un identificateur, un littéral ou une expression arithmétique. La comparaison algébrique des champs numériques est effectuée indépendamment de la taille et de la clause d'utilisation.

For non-numeric operands

Si deux opérandes non numériques de taille égale sont comparés, alors les caractères sont comparés de gauche avec les positions correspondantes jusqu'à ce que la fin soit atteinte. L'opérande contenant le plus grand nombre de caractères est déclaré supérieur.

Si deux opérandes non numériques de taille inégale sont comparés, alors l'élément de données le plus court est ajouté avec des espaces à la fin jusqu'à ce que la taille des opérandes devienne égale, puis comparé selon les règles mentionnées au point précédent.

Syntaxe

Vous trouverez ci-dessous la syntaxe des instructions de condition de relation -

[Data Name/Arithmetic Operation]

   [IS] [NOT] 

[Equal to (=),Greater than (>), Less than (<), 
Greater than or Equal (>=), Less than or equal (<=) ]

[Data Name/Arithmetic Operation]

Example

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.

DATA DIVISION.
   WORKING-STORAGE SECTION.
   01 WS-NUM1 PIC 9(9).
   01 WS-NUM2 PIC 9(9).

PROCEDURE DIVISION.
   A000-FIRST-PARA.
   MOVE 25 TO WS-NUM1.
   MOVE 15 TO WS-NUM2.
   
   IF WS-NUM1 IS GREATER THAN OR EQUAL TO WS-NUM2 THEN
      DISPLAY 'WS-NUM1 IS GREATER THAN WS-NUM2'
   ELSE
      DISPLAY 'WS-NUM1 IS LESS THAN WS-NUM2'
   END-IF.
   
STOP RUN.

JCL pour exécuter le programme COBOL ci-dessus -

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO

Lorsque vous compilez et exécutez le programme ci-dessus, il produit le résultat suivant -

WS-NUM1 IS GREATER THAN WS-NUM2

État du signe

La condition de signe est utilisée pour vérifier le signe d'un opérande numérique. Il détermine si une valeur numérique donnée est supérieure, inférieure ou égale à ZERO.

Syntaxe

Voici la syntaxe des instructions de condition Sign -

[Data Name/Arithmetic Operation] 

   [IS] [NOT] 

[Positive, Negative or Zero]

[Data Name/Arithmetic Operation]

Example

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.

DATA DIVISION.
   WORKING-STORAGE SECTION.
   01 WS-NUM1 PIC S9(9) VALUE -1234.
   01 WS-NUM2 PIC S9(9) VALUE 123456.

PROCEDURE DIVISION.
   A000-FIRST-PARA.
   IF WS-NUM1 IS POSITIVE THEN
      DISPLAY 'WS-NUM1 IS POSITIVE'.
      
   IF WS-NUM1 IS NEGATIVE THEN
      DISPLAY 'WS-NUM1 IS NEGATIVE'.
      
   IF WS-NUM1 IS ZERO THEN
      DISPLAY 'WS-NUM1 IS ZERO'.
      
   IF WS-NUM2 IS POSITIVE THEN
      DISPLAY 'WS-NUM2 IS POSITIVE'.

STOP RUN.

JCL pour exécuter le programme COBOL ci-dessus -

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO

Lorsque vous compilez et exécutez le programme ci-dessus, il produit le résultat suivant -

WS-NUM1 IS NEGATIVE
WS-NUM2 IS POSITIVE

Condition de classe

La condition de classe est utilisée pour vérifier si un opérande contient uniquement des alphabets ou des données numériques. Les espaces sont pris en compte dans ALPHABETIC, ALPHABETIC-LOWER et ALPHABETIC-UPPER.

Syntaxe

Voici la syntaxe des instructions de condition de classe -

[Data Name/Arithmetic Operation>]

   [IS] [NOT] 

[NUMERIC, ALPHABETIC, ALPHABETIC-LOWER, ALPHABETIC-UPPER]

[Data Name/Arithmetic Operation]

Example

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.

DATA DIVISION.
   WORKING-STORAGE SECTION.
   01 WS-NUM1 PIC X(9) VALUE 'ABCD '.
   01 WS-NUM2 PIC 9(9) VALUE 123456789.

PROCEDURE DIVISION.
   A000-FIRST-PARA.
   
   IF WS-NUM1 IS ALPHABETIC THEN
      DISPLAY 'WS-NUM1 IS ALPHABETIC'.
      
   IF WS-NUM1 IS NUMERIC THEN
      DISPLAY 'WS-NUM1 IS NUMERIC'.
      
   IF WS-NUM2 IS NUMERIC THEN
      DISPLAY 'WS-NUM2 IS NUMERIC'.
   
STOP RUN.

JCL pour exécuter le programme COBOL ci-dessus -

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO

Lorsque vous compilez et exécutez le programme ci-dessus, il produit le résultat suivant -

WS-NUM1 IS ALPHABETIC
WS-NUM2 IS NUMERIC

Condition-name Condition

Un nom de condition est un nom défini par l'utilisateur. Il contient un ensemble de valeurs spécifiées par l'utilisateur. Il se comporte comme des variables booléennes. Ils sont définis avec le numéro de niveau 88. Il n'aura pas de clause PIC.

Syntaxe

Voici la syntaxe des instructions de condition définies par l'utilisateur -

88 [Condition-Name] VALUE [IS, ARE] [LITERAL] [THRU LITERAL].

Example

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.

DATA DIVISION.
   WORKING-STORAGE SECTION.
   01 WS-NUM PIC 9(3).
   88 PASS VALUES ARE 041 THRU 100.
   88 FAIL VALUES ARE 000 THRU 40.

PROCEDURE DIVISION.
   A000-FIRST-PARA.
   MOVE 65 TO WS-NUM.
   
   IF PASS 
      DISPLAY 'Passed with ' WS-NUM ' marks'.
      
   IF FAIL 
      DISPLAY 'FAILED with ' WS-NUM 'marks'.
      
STOP RUN.

JCL pour exécuter le programme COBOL ci-dessus -

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO

Lorsque vous compilez et exécutez le programme ci-dessus, il produit le résultat suivant -

Passed with 065 marks

Condition annulée

La condition annulée est donnée en utilisant le mot clé NOT. Si une condition est vraie et que nous avons donné NOT devant elle, alors sa valeur finale sera fausse.

Syntaxe

Voici la syntaxe des instructions de condition négées -

IF NOT [CONDITION] 
   COBOL Statements
END-IF.

Example

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.

DATA DIVISION.
   WORKING-STORAGE SECTION.
   01 WS-NUM1 PIC 9(2) VALUE 20.
   01 WS-NUM2 PIC 9(9) VALUE 25.

PROCEDURE DIVISION.
   A000-FIRST-PARA.
   
   IF NOT WS-NUM1 IS LESS THAN WS-NUM2 THEN
      DISPLAY 'IF-BLOCK'
   ELSE
      DISPLAY 'ELSE-BLOCK'
   END-IF.
   
STOP RUN.

JCL pour exécuter le programme COBOL ci-dessus -

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO

Lorsque vous compilez et exécutez le programme ci-dessus, il produit le résultat suivant -

ELSE-BLOCK

Condition combinée

Une condition combinée contient deux conditions ou plus connectées à l'aide des opérateurs logiques ET ou OU.

Syntaxe

Voici la syntaxe des instructions de condition combinées -

IF [CONDITION] AND [CONDITION]
   COBOL Statements
END-IF.

Example

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.

DATA DIVISION.
   WORKING-STORAGE SECTION.
   01 WS-NUM1 PIC 9(2) VALUE 20.
   01 WS-NUM2 PIC 9(2) VALUE 25.
   01 WS-NUM3 PIC 9(2) VALUE 20.

PROCEDURE DIVISION.
   A000-FIRST-PARA.
   
   IF WS-NUM1 IS LESS THAN WS-NUM2 AND WS-NUM1=WS-NUM3 THEN
      DISPLAY 'Both condition OK'
   ELSE
      DISPLAY 'Error'
   END-IF.
   
STOP RUN.

JCL pour exécuter le programme COBOL ci-dessus -

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO

Lorsque vous compilez et exécutez le programme ci-dessus, il produit le résultat suivant -

Both condition OK

Évaluer le verbe

Le verbe Evaluate remplace une série d'instructions IF-ELSE. Il peut être utilisé pour évaluer plus d'une condition. Elle est similaire à l'instruction SWITCH dans les programmes C.

Example

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.

DATA DIVISION.
   WORKING-STORAGE SECTION.
   01 WS-A PIC 9 VALUE 0.
   
PROCEDURE DIVISION.
   MOVE 3 TO WS-A.
   
   EVALUATE TRUE
      WHEN WS-A > 2
         DISPLAY 'WS-A GREATER THAN 2'

      WHEN WS-A < 0
         DISPLAY 'WS-A LESS THAN 0'

      WHEN OTHER
         DISPLAY 'INVALID VALUE OF WS-A'
   END-EVALUATE.
   
STOP RUN.

JCL pour exécuter le programme COBOL ci-dessus -

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO

Lorsque vous compilez et exécutez le programme ci-dessus, il produit le résultat suivant -

WS-A GREATER THAN 2

Certaines tâches doivent être répétées encore et encore, comme la lecture de chaque enregistrement d'un fichier jusqu'à sa fin. Les instructions de boucle utilisées dans COBOL sont -

  • Effectuer à travers
  • Effectuer jusqu'à
  • Temps d'exécution
  • Effectuer des variations

Effectuer à travers

Perform Thru est utilisé pour exécuter une série de paragraphes en donnant les noms de premier et dernier paragraphe de la séquence. Après avoir exécuté le dernier paragraphe, le contrôle est renvoyé.

Performer en ligne

Les instructions à l'intérieur de PERFORM seront exécutées jusqu'à ce que END-PERFORM soit atteint.

Syntaxe

Voici la syntaxe de l'exécution en ligne -

PERFORM 
   DISPLAY 'HELLO WORLD'
END-PERFORM.

Performances hors ligne

Ici, une instruction est exécutée dans un paragraphe, puis le contrôle est transféré vers un autre paragraphe ou une autre section.

Syntaxe

Voici la syntaxe de l'exécution hors ligne -

PERFORM PARAGRAPH1 THRU PARAGRAPH2

Example

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.

PROCEDURE DIVISION.
   A-PARA.
   PERFORM DISPLAY 'IN A-PARA'
   END-PERFORM.
   PERFORM C-PARA THRU E-PARA.
   
   B-PARA.
   DISPLAY 'IN B-PARA'.
   STOP RUN.
   
   C-PARA.
   DISPLAY 'IN C-PARA'.
   
   D-PARA.
   DISPLAY 'IN D-PARA'.
   
   E-PARA.
   DISPLAY 'IN E-PARA'.

JCL pour exécuter le programme COBOL ci-dessus.

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO

Lorsque vous compilez et exécutez le programme ci-dessus, il produit le résultat suivant -

IN A-PARA
IN C-PARA
IN D-PARA
IN E-PARA
IN B-PARA

Effectuer jusqu'à

Dans 'exécuter jusqu'à', un paragraphe est exécuté jusqu'à ce que la condition donnée devienne vraie. «Avec test avant» est la condition par défaut et indique que la condition est vérifiée avant l'exécution des instructions dans un paragraphe.

Syntaxe

Voici la syntaxe de perform jusqu'à -

PERFORM A-PARA UNTIL COUNT=5

PERFORM A-PARA WITH TEST BEFORE UNTIL COUNT=5

PERFORM A-PARA WITH TEST AFTER UNTIL COUNT=5

Example

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.

DATA DIVISION.
   WORKING-STORAGE SECTION.
   01 WS-CNT PIC 9(1) VALUE 0. 

PROCEDURE DIVISION.
   A-PARA.
   PERFORM B-PARA WITH TEST AFTER UNTIL WS-CNT>3.
   STOP RUN.
   
   B-PARA.
   DISPLAY 'WS-CNT : 'WS-CNT.
   ADD 1 TO WS-CNT.

JCL pour exécuter le programme COBOL ci-dessus -

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO

Lorsque vous compilez et exécutez le programme ci-dessus, il produit le résultat suivant -

WS-CNT : 0
WS-CNT : 1
WS-CNT : 2
WS-CNT : 3

Temps d'exécution

Dans 'perform times', un paragraphe sera exécuté le nombre de fois spécifié.

Syntaxe

Voici la syntaxe des temps d'exécution -

PERFORM A-PARA 5 TIMES.

Example

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.

PROCEDURE DIVISION.
   A-PARA.
   PERFORM B-PARA 3 TIMES.
   STOP RUN.
   
   B-PARA.
   DISPLAY 'IN B-PARA'.

JCL pour exécuter le programme COBOL ci-dessus -

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO

Lorsque vous compilez et exécutez le programme ci-dessus, il produit le résultat suivant -

IN B-PARA
IN B-PARA
IN B-PARA

Effectuer des variations

Lors de l'exécution de la variation, un paragraphe sera exécuté jusqu'à ce que la condition de la phrase Until devienne vraie.

Syntaxe

Voici la syntaxe de perform variant -

PERFORM A-PARA VARYING A FROM 1 BY 1 UNTIL A = 5.

Example

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.

DATA DIVISION.
   WORKING-STORAGE SECTION.
   01 WS-A PIC 9 VALUE 0.

PROCEDURE DIVISION.
   A-PARA.
   PERFORM B-PARA VARYING WS-A FROM 1 BY 1 UNTIL WS-A=5
   STOP RUN.
   
   B-PARA.
   DISPLAY 'IN B-PARA ' WS-A.

JCL pour exécuter le programme COBOL ci-dessus -

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO

Lorsque vous compilez et exécutez le programme ci-dessus, il produit le résultat suivant -

IN B-PARA 1
IN B-PARA 2
IN B-PARA 3
IN B-PARA 4

ALLER À Déclaration

L'instruction GO TO est utilisée pour modifier le flux d'exécution dans un programme. Dans les instructions GO TO, le transfert s'effectue uniquement dans le sens direct. Il est utilisé pour quitter un paragraphe. Les différents types d'instructions GO TO utilisés sont les suivants -

Inconditionnel ALLER À

GO TO para-name.

Conditionnel ALLER À

GO TO para-1 para-2 para-3 DEPENDING ON x.

Si «x» est égal à 1, alors le contrôle sera transféré au premier paragraphe; et si «x» est égal à 2, alors le contrôle sera transféré au deuxième paragraphe, et ainsi de suite.

Example

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.

DATA DIVISION.
   WORKING-STORAGE SECTION.
   01 WS-A PIC 9 VALUE 2.
   
PROCEDURE DIVISION.
   A-PARA.
   DISPLAY 'IN A-PARA'
   GO TO B-PARA.
   
   B-PARA.
   DISPLAY 'IN B-PARA '.
   GO TO C-PARA D-PARA DEPENDING ON WS-A.
   
   C-PARA.
   DISPLAY 'IN C-PARA '.
   
   D-PARA.
   DISPLAY 'IN D-PARA '.
   STOP RUN.

JCL pour exécuter le programme COBOL ci-dessus:

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO

Lorsque vous compilez et exécutez le programme ci-dessus, il produit le résultat suivant:

IN A-PARA
IN B-PARA 
IN D-PARA

Les instructions de gestion de chaîne dans COBOL sont utilisées pour effectuer plusieurs opérations fonctionnelles sur des chaînes. Voici les instructions de gestion des chaînes -

  • Inspect
  • String
  • Unstring

Inspecter

Le verbe Inspect est utilisé pour compter ou remplacer les caractères dans une chaîne. Les opérations de chaîne peuvent être effectuées sur des valeurs alphanumériques, numériques ou alphabétiques. Les opérations d'inspection sont effectuées de gauche à droite. Les options utilisées pour les opérations sur les chaînes sont les suivantes -

Comptage

L'option Tallying est utilisée pour compter les caractères de la chaîne.

Syntax

Voici la syntaxe de l'option Tallying -

INSPECT input-string
TALLYING output-count FOR ALL CHARACTERS

Les paramètres utilisés sont -

  • input-string - La chaîne dont les caractères doivent être comptés.
  • output-count - Élément de données contenant le nombre de caractères.

Example

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.

DATA DIVISION.
   WORKING-STORAGE SECTION.
   01 WS-CNT1 PIC 9(2) VALUE 0.
   01 WS-CNT2 PIC 9(2) VALUE 0.
   01 WS-STRING PIC X(15) VALUE 'ABCDACDADEAAAFF'.
   
PROCEDURE DIVISION.
   INSPECT WS-STRING TALLYING WS-CNT1 FOR CHARACTER.
   DISPLAY "WS-CNT1 : "WS-CNT1.
   INSPECT WS-STRING TALLYING WS-CNT2 FOR ALL 'A'.
   DISPLAY "WS-CNT2 : "WS-CNT2
   
STOP RUN.

JCL pour exécuter le programme COBOL ci-dessus.

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO

Lorsque vous compilez et exécutez le programme ci-dessus, il produit le résultat suivant -

WS-CNT1 : 15
WS-CNT2 : 06

Remplacement

L'option de remplacement est utilisée pour remplacer les caractères de chaîne.

Syntax

Voici la syntaxe de l'option de remplacement -

INSPECT input-string REPLACING ALL char1 BY char2.

Le paramètre utilisé est -

  • input-string - La chaîne dont les caractères doivent être remplacés de char1 à char2.

Example

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.

DATA DIVISION.
   WORKING-STORAGE SECTION.
   01 WS-STRING PIC X(15) VALUE 'ABCDACDADEAAAFF'.

PROCEDURE DIVISION.
   DISPLAY "OLD STRING : "WS-STRING.
   INSPECT WS-STRING REPLACING ALL 'A' BY 'X'.
   DISPLAY "NEW STRING : "WS-STRING.
   
STOP RUN.

JCL pour exécuter le programme COBOL ci-dessus.

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO

Lorsque vous compilez et exécutez le programme ci-dessus, il produit le résultat suivant -

OLD STRING : ABCDACDADEAAAFF
NEW STRING : XBCDXCDXDEXXXFF

Chaîne

Le verbe de chaîne est utilisé pour concaténer les chaînes. À l'aide de l'instruction STRING, deux ou plusieurs chaînes de caractères peuvent être combinées pour former une chaîne plus longue. La clause «délimité par» est obligatoire.

Syntax

Voici la syntaxe du verbe String -

STRING ws-string1 DELIMITED BY SPACE
   ws-string2 DELIMITED BY SIZE
   INTO ws-destination-string
   WITH POINTER ws-count
   ON OVERFLOW DISPLAY message1
   NOT ON OVERFLOW DISPLAY message2
END-STRING.

Voici les détails des paramètres utilisés -

  • ws-string1 et ws-string2: chaînes d'entrée à concaténer
  • ws-string: chaîne de sortie
  • ws-count: utilisé pour compter la longueur de la nouvelle chaîne concaténée
  • Délimité spécifie la fin de la chaîne
  • Le pointeur et le débordement sont facultatifs

Example

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.

DATA DIVISION.
   WORKING-STORAGE SECTION.
   01 WS-STRING PIC A(30).
   01 WS-STR1 PIC A(15) VALUE 'Tutorialspoint'.
   01 WS-STR2 PIC A(7) VALUE 'Welcome'.
   01 WS-STR3 PIC A(7) VALUE 'To AND'.
   01 WS-COUNT PIC 99 VALUE 1.

PROCEDURE DIVISION.
   STRING WS-STR2 DELIMITED BY SIZE
      WS-STR3 DELIMITED BY SPACE
      WS-STR1 DELIMITED BY SIZE
      INTO WS-STRING 
      WITH POINTER WS-COUNT
      ON OVERFLOW DISPLAY 'OVERFLOW!' 
   END-STRING.
   
   DISPLAY 'WS-STRING : 'WS-STRING.
   DISPLAY 'WS-COUNT : 'WS-COUNT.

STOP RUN.

JCL pour exécuter le programme COBOL ci-dessus -

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO

Lorsque vous compilez et exécutez le programme ci-dessus, il produit le résultat suivant -

WS-STRING : WelcomeToTutorialspoint       
WS-COUNT : 25

Détendre les cordes

Le verbe Unstring est utilisé pour diviser une chaîne en plusieurs sous-chaînes. La clause Delimited By est obligatoire.

Syntax

Voici la syntaxe du verbe Unstring -

UNSTRING ws-string DELIMITED BY SPACE
INTO ws-str1, ws-str2
WITH POINTER ws-count
ON OVERFLOW DISPLAY message
NOT ON OVERFLOW DISPLAY message
END-UNSTRING.

Example

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.

DATA DIVISION.
   WORKING-STORAGE SECTION.
   01 WS-STRING PIC A(30) VALUE 'WELCOME TO TUTORIALSPOINT'.
   01 WS-STR1 PIC A(7).
   01 WS-STR2 PIC A(2).
   01 WS-STR3 PIC A(15).
   01 WS-COUNT PIC 99 VALUE 1.

PROCEDURE DIVISION.
   UNSTRING WS-STRING DELIMITED BY SPACE
      INTO WS-STR1, WS-STR2, WS-STR3
   END-UNSTRING.
   
   DISPLAY 'WS-STR1 : 'WS-STR1.
   DISPLAY 'WS-STR2 : 'WS-STR2.
   DISPLAY 'WS-STR3 : 'WS-STR3.
   
STOP RUN.

JCL pour exécuter le programme COBOL ci-dessus -

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO

Lorsque vous compilez et exécutez le programme ci-dessus, il produit le résultat suivant -

WS-STR1 : WELCOME
WS-STR2 : TO
WS-STR3 : TUTORIALSPOINT

Les tableaux en COBOL sont appelés tableaux. Un tableau est une structure de données linéaire et est une collection d'éléments de données individuels du même type. Les éléments de données d'une table sont triés en interne.

Déclaration de table

La table est déclarée dans Data Division. Occursclause est utilisée pour définir une table. La clause Occurs indique la répétition de la définition du nom de données. Il ne peut être utilisé qu'avec des numéros de niveau allant de 02 à 49. Ne pas utiliser la clause survient avec Redefines. La description du tableau unidimensionnel et bidimensionnel est la suivante -

Table unidimensionnelle

Dans un tableau unidimensionnel, occursLa clause n'est utilisée qu'une seule fois dans la déclaration. WSTABLE est l'élément de groupe qui contient la table. WS-B nomme les éléments de table qui se produisent 10 fois.

Syntax

Voici la syntaxe pour définir une table unidimensionnelle -

01 WS-TABLE.
   05 WS-A PIC A(10) OCCURS 10 TIMES.

Example

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.

DATA DIVISION.
   WORKING-STORAGE SECTION.
   01 WS-TABLE.
      05 WS-A PIC A(10) VALUE 'TUTORIALS' OCCURS 5 TIMES.     

PROCEDURE DIVISION.
   DISPLAY "ONE-D TABLE : "WS-TABLE.
STOP RUN.

JCL pour exécuter le programme COBOL ci-dessus -

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO

Lorsque vous compilez et exécutez le programme ci-dessus, il produit le résultat suivant -

ONE-D TABLE : TUTORIALS TUTORIALS TUTORIALS TUTORIALS TUTORIALS

Table bidimensionnelle

Une table bidimensionnelle est créée avec les deux éléments de données de longueur variable. Pour référence, parcourez la syntaxe, puis essayez d'analyser le tableau. Le premier tableau (WS-A) peut apparaître de 1 à 10 fois et le tableau interne (WS-C) peut apparaître de 1 à 5 fois. Pour chaque entrée de WS-A, il y aura 5 entrées correspondantes de WS-C.

Syntax

Voici la syntaxe pour définir une table à deux dimensions -

01 WS-TABLE.
   05 WS-A OCCURS 10 TIMES.
      10 WS-B PIC A(10).
      10 WS-C OCCURS 5 TIMES.
         15 WS-D PIC X(6).

Example

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.

DATA DIVISION.
   WORKING-STORAGE SECTION.
   01 WS-TABLE.
      05 WS-A OCCURS 2 TIMES.
         10 WS-B PIC A(10) VALUE ' TUTORIALS'.
         10 WS-C OCCURS 2 TIMES.
            15 WS-D PIC X(6) VALUE ' POINT'.

PROCEDURE DIVISION.
   DISPLAY "TWO-D TABLE : "WS-TABLE.

STOP RUN.

JCL pour exécuter le programme COBOL ci-dessus -

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO

Lorsque vous compilez et exécutez le programme ci-dessus, il produit le résultat suivant -

TWO-D TABLE :  TUTORIALS POINT POINT TUTORIALS POINT POINT

Indice

Les éléments individuels du tableau sont accessibles à l'aide de l'indice. Les valeurs de l'indice peuvent aller de 1 au nombre de fois où la table apparaît. Un indice peut être n'importe quel nombre positif. Il ne nécessite aucune déclaration dans la division des données. Il est automatiquement créé avec la clause survient.

Example

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.

DATA DIVISION.
   WORKING-STORAGE SECTION.
   01 WS-TABLE.
      05 WS-A OCCURS 3 TIMES.
         10 WS-B PIC A(2).
         10 WS-C OCCURS 2 TIMES.
            15 WS-D PIC X(3).

PROCEDURE DIVISION.
   MOVE '12ABCDEF34GHIJKL56MNOPQR' TO WS-TABLE.
   DISPLAY 'WS-TABLE  : ' WS-TABLE.
   DISPLAY 'WS-A(1)   : ' WS-A(1).
   DISPLAY 'WS-C(1,1) : ' WS-C(1,1).
   DISPLAY 'WS-C(1,2) : ' WS-C(1,2).
   DISPLAY 'WS-A(2)   : ' WS-A(2).
   DISPLAY 'WS-C(2,1) : ' WS-C(2,1).
   DISPLAY 'WS-C(2,2) : ' WS-C(2,2).
   DISPLAY 'WS-A(3)   : ' WS-A(3).
   DISPLAY 'WS-C(3,1) : ' WS-C(3,1).
   DISPLAY 'WS-C(3,2) : ' WS-C(3,2).
   
STOP RUN.

JCL pour exécuter le programme COBOL ci-dessus -

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO

Lorsque vous compilez et exécutez le programme ci-dessus, il produit le résultat suivant -

WS-TABLE  : 12ABCDEF34GHIJKL56MNOPQR
WS-A(1)   : 12ABCDEF
WS-C(1,1) : ABC
WS-C(1,2) : DEF
WS-A(2)   : 34GHIJKL
WS-C(2,1) : GHI
WS-C(2,2) : JKL
WS-A(3)   : 56MNOPQR
WS-C(3,1) : MNO
WS-C(3,2) : PQR

Indice

Les éléments de table sont également accessibles à l'aide de l'index. Un index est un déplacement d'élément depuis le début de la table. Un index est déclaré avec la clause Occurs à l'aide de la clause INDEXED BY. La valeur de l'index peut être modifiée à l'aide de l'instruction SET et de l'option PERFORM Varying.

Syntax

Voici la syntaxe pour définir l'index dans une table -

01 WS-TABLE.
   05 WS-A PIC A(10) OCCURS 10 TIMES INDEXED BY I.

Example

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.

DATA DIVISION.
   WORKING-STORAGE SECTION.
   01 WS-TABLE.
      05 WS-A OCCURS 3 TIMES INDEXED BY I.
         10 WS-B PIC A(2).
         10 WS-C OCCURS 2 TIMES INDEXED BY J.
            15 WS-D PIC X(3).

PROCEDURE DIVISION.
   MOVE '12ABCDEF34GHIJKL56MNOPQR' TO WS-TABLE.
   PERFORM A-PARA VARYING I FROM 1 BY 1 UNTIL I >3 
   STOP RUN.
   
   A-PARA.
   PERFORM C-PARA VARYING J FROM 1 BY 1 UNTIL J>2.
   
   C-PARA.
   DISPLAY WS-C(I,J).

JCL pour exécuter le programme COBOL ci-dessus -

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO

Lorsque vous compilez et exécutez le programme ci-dessus, il produit le résultat suivant -

ABC
DEF
GHI
JKL
MNO
PQR

Définir la déclaration

L'instruction Set est utilisée pour modifier la valeur d'index. Le verbe Set est utilisé pour initialiser, incrémenter ou décrémenter la valeur d'index. Il est utilisé avec Rechercher et Rechercher tout pour localiser les éléments dans le tableau.

Syntax

Voici la syntaxe pour utiliser une instruction Set -

SET I J TO positive-number
SET I TO J
SET I TO 5
SET I J UP BY 1
SET J DOWN BY 5

Example

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.

DATA DIVISION.
   WORKING-STORAGE SECTION.
   01 WS-TABLE.
      05 WS-A OCCURS 3 TIMES INDEXED BY I.
         10 WS-B PIC A(2).
         10 WS-C OCCURS 2 TIMES INDEXED BY J.
            15 WS-D PIC X(3).

PROCEDURE DIVISION.
   MOVE '12ABCDEF34GHIJKL56MNOPQR' TO WS-TABLE.
   SET I J TO 1.
   DISPLAY WS-C(I,J).
   SET I J UP BY 1.
   DISPLAY WS-C(I,J).
   
STOP RUN.

JCL pour exécuter le programme COBOL ci-dessus.

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO

Lorsque vous compilez et exécutez le programme ci-dessus, il produit le résultat suivant -

ABC
JKL

Chercher

La recherche est une méthode de recherche linéaire utilisée pour rechercher des éléments à l'intérieur du tableau. Il peut être effectué sur une table triée ou non triée. Il n'est utilisé que pour les tables déclarées par la phrase d'index. Il commence par la valeur initiale de l'index. Si l'élément recherché n'est pas trouvé, l'index est automatiquement incrémenté de 1 et il continue jusqu'à la fin de la table.

Example

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.

DATA DIVISION.
   WORKING-STORAGE SECTION.
   01 WS-TABLE.
      05 WS-A PIC X(1) OCCURS 18 TIMES INDEXED BY I.
   01 WS-SRCH PIC A(1) VALUE 'M'.

PROCEDURE DIVISION.
   MOVE 'ABCDEFGHIJKLMNOPQR' TO WS-TABLE.
   SET I TO 1.
   SEARCH WS-A
      AT END DISPLAY 'M NOT FOUND IN TABLE'
      WHEN WS-A(I) = WS-SRCH
      DISPLAY 'LETTER M FOUND IN TABLE'
   END-SEARCH.  

STOP RUN.

JCL pour exécuter le programme COBOL ci-dessus.

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO

Lorsque vous compilez et exécutez le programme ci-dessus, il produit le résultat suivant -

LETTER M FOUND IN TABLE

Rechercher tout

Search All est une méthode de recherche binaire, qui est utilisée pour trouver des éléments à l'intérieur de la table. Le tableau doit être trié pour l'option Rechercher tout. L'index ne nécessite pas d'initialisation. Dans la recherche binaire, le tableau est divisé en deux moitiés et détermine dans quelle moitié l'élément recherché est présent. Ce processus se répète jusqu'à ce que l'élément soit trouvé ou que la fin soit atteinte.

Example

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.

DATA DIVISION.
   WORKING-STORAGE SECTION.
   01 WS-TABLE.
      05 WS-RECORD OCCURS 10 TIMES ASCENDING KEY IS WS-NUM INDEXED BY I.
      10 WS-NUM PIC 9(2).
      10 WS-NAME PIC A(3).

PROCEDURE DIVISION.
   MOVE '12ABC56DEF34GHI78JKL93MNO11PQR' TO WS-TABLE.
   SEARCH ALL WS-RECORD
     AT END DISPLAY 'RECORD NOT FOUND'
     WHEN WS-NUM(I) = 93
     DISPLAY 'RECORD FOUND '
     DISPLAY WS-NUM(I)
     DISPLAY WS-NAME(I)

END-SEARCH.

JCL pour exécuter le programme COBOL ci-dessus -

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO

Lorsque vous compilez et exécutez le programme ci-dessus, il produit le résultat suivant -

RECORD FOUND 
93
MNO

Le concept de fichiers en COBOL est différent de celui en C / C ++. Lors de l'apprentissage des bases de «File» en COBOL, les concepts des deux langues ne doivent pas être corrélés. Les fichiers texte simples ne peuvent pas être utilisés dans COBOL, à la placePS (Physical Sequential) et VSAMles fichiers sont utilisés. Les fichiers PS seront abordés dans ce module.

Pour comprendre la gestion des fichiers en COBOL, il faut connaître les termes de base. Ces conditions ne servent qu'à comprendre les principes fondamentaux de la gestion des fichiers. Une terminologie plus approfondie sera discutée dans le chapitre «Verbes de gestion de fichiers». Voici les termes de base -

  • Field
  • Record
  • Dossier physique
  • Enregistrement logique
  • File

L'exemple suivant aide à comprendre ces termes -

Champ

Le champ est utilisé pour indiquer les données stockées sur un élément. Il représente un élément unique comme indiqué dans l'exemple ci-dessus, tel que l'identifiant de l'élève, le nom, les notes, le total des notes et le pourcentage. Le nombre de caractères dans n'importe quel champ est appelé taille de champ, par exemple, le nom de l'élève peut avoir 10 caractères. Les champs peuvent avoir les attributs suivants -

  • Primary keyssont les champs qui sont uniques à chaque enregistrement et sont utilisés pour identifier un enregistrement particulier. Par exemple, dans le fichier de notes des étudiants, chaque étudiant aura un identifiant d'étudiant unique qui constitue la clé primaire.

  • Secondary keyssont des champs uniques ou non uniques utilisés pour rechercher des données associées. Par exemple, dans le fichier de notes des élèves, le nom complet de l'élève peut être utilisé comme clé secondaire lorsque l'identifiant de l'élève n'est pas connu.

  • Descriptorsles champs sont utilisés pour décrire une entité. Par exemple, chez les élèves, le fichier de notes, les notes et les champs de pourcentage qui ajoutent du sens à l'enregistrement sont des descripteurs connus.

Record

Record est une collection de champs utilisée pour décrire une entité. Un ou plusieurs champs forment ensemble un enregistrement. Par exemple, dans le fichier de notes des élèves, l'identifiant de l'élève, le nom, les notes, le total des notes et le pourcentage forment un enregistrement. La taille cumulée de tous les champs d'un enregistrement est appelée taille d'enregistrement. Les enregistrements présents dans un fichier peuvent être de longueur fixe ou de longueur variable.

Dossier physique

L'enregistrement physique correspond aux informations qui existent sur le périphérique externe. Il est également connu sous le nom de bloc.

Enregistrement logique

L'enregistrement logique est l'information utilisée par le programme. Dans les programmes COBOL, un seul enregistrement peut être traité à tout moment et il est appelé comme enregistrement logique.

Fichier

Le fichier est une collection d'enregistrements associés. Par exemple, le fichier des notes des élèves comprend les enregistrements de tous les élèves.

L'organisation des fichiers indique comment les enregistrements sont organisés dans un fichier. Il existe différents types d'organisations pour les fichiers afin d'augmenter leur efficacité d'accès aux enregistrements. Voici les types de schémas d'organisation de fichiers -

  • Organisation séquentielle des fichiers
  • Organisation des fichiers séquentiels indexés
  • Organisation relative des fichiers

Les syntaxes de ce module, mentionnées avec leurs termes respectifs, se réfèrent uniquement à leur utilisation dans le programme. Les programmes complets utilisant ces syntaxes seront discutés dans le chapitre «Verbes de gestion de fichiers».

Organisation séquentielle des fichiers

Un fichier séquentiel se compose d'enregistrements stockés et accessibles dans un ordre séquentiel. Voici les principaux attributs de l'organisation séquentielle des fichiers -

  • Les enregistrements peuvent être lus dans un ordre séquentiel. Pour lire le 10 e enregistrement, tous les 9 enregistrements précédents doivent être lus.

  • Les enregistrements sont écrits dans un ordre séquentiel. Un nouvel enregistrement ne peut pas être inséré entre les deux. Un nouvel enregistrement est toujours inséré à la fin du fichier.

  • Après avoir placé un enregistrement dans un fichier séquentiel, il n'est pas possible de supprimer, de raccourcir ou d'allonger un enregistrement.

  • L'ordre des enregistrements, une fois insérés, ne peut jamais être modifié.

  • La mise à jour du dossier est possible. Un enregistrement peut être écrasé si la nouvelle longueur d'enregistrement est la même que l'ancienne longueur d'enregistrement.

  • Les fichiers de sortie séquentiels sont une bonne option pour l'impression.

Syntaxe

Voici la syntaxe de l'organisation séquentielle des fichiers -

INPUT-OUTPUT SECTION.
FILE-CONTROL.
   SELECT file-name ASSIGN TO dd-name-jcl
   ORGANIZATION IS SEQUENTIAL

Organisation des fichiers séquentiels indexés

Un fichier séquentiel indexé se compose d'enregistrements auxquels il est possible d'accéder de manière séquentielle. Un accès direct est également possible. Il se compose de deux parties -

  • Data File contient des enregistrements dans un schéma séquentiel.

  • Index File contient la clé primaire et son adresse dans le fichier de données.

Voici les principaux attributs de l'organisation séquentielle des fichiers -

  • Les enregistrements peuvent être lus dans un ordre séquentiel, tout comme dans l'organisation séquentielle des fichiers.

  • Les enregistrements sont accessibles de manière aléatoire si la clé primaire est connue. Le fichier d'index est utilisé pour obtenir l'adresse d'un enregistrement, puis l'enregistrement est extrait du fichier de données.

  • L'index trié est conservé dans ce système de fichiers qui relie la valeur de clé à la position de l'enregistrement dans le fichier.

  • Un autre index peut également être créé pour récupérer les enregistrements.

Syntaxe

Voici la syntaxe de l'organisation des fichiers séquentiels indexés -

INPUT-OUTPUT SECTION.
FILE-CONTROL.
   SELECT file-name ASSIGN TO dd-name-jcl
   ORGANIZATION IS INDEXED
   RECORD KEY IS primary-key
   ALTERNATE RECORD KEY IS rec-key

Organisation relative des fichiers

Un fichier relatif se compose d'enregistrements classés par relative address. Voici les principaux attributs de l'organisation relative des fichiers -

  • Les enregistrements peuvent être lus dans un ordre séquentiel, tout comme dans une organisation de fichiers séquentielle et indexée.

  • Les enregistrements sont accessibles à l'aide de la clé relative. La clé relative représente l'emplacement de l'enregistrement par rapport à l'adresse du début du fichier.

  • Les enregistrements peuvent être insérés en utilisant la clé relative. L'adresse relative est calculée à l'aide de la clé relative.

  • Le fichier relatif fournit l'accès le plus rapide aux enregistrements.

  • Le principal inconvénient de ce système de fichiers est que si certains enregistrements intermédiaires sont manquants, ils occuperont également de l'espace.

Syntaxe

Voici la syntaxe de l'organisation relative des fichiers -

INPUT-OUTPUT SECTION.
FILE-CONTROL.
   SELECT file-name ASSIGN TO dd-name-jcl
   ORGANIZATION IS RELATIVE
   RELATIVE KEY IS rec-key

Jusqu'à présent, les schémas d'organisation des fichiers ont été discutés. Pour chaque schéma d'organisation des fichiers, différents modes d'accès peuvent être utilisés. Voici les types de modes d'accès aux fichiers -

  • Accès séquentiel
  • Accès aléatoire
  • Accès dynamique

Les syntaxes de ce module, mentionnées avec leurs termes respectifs, se réfèrent uniquement à leur utilisation dans le programme. Les programmes complets utilisant ces syntaxes seront discutés dans le chapitre suivant.

Accès séquentiel

Lorsque le mode d'accès est séquentiel, la méthode de récupération des enregistrements change selon l'organisation de fichiers sélectionnée.

  • Pour sequential files, les enregistrements sont accessibles dans le même ordre dans lequel ils ont été insérés.

  • Pour indexed files, le paramètre utilisé pour récupérer les enregistrements sont les valeurs de clé d'enregistrement.

  • Pour relative files, les clés d'enregistrement relatives sont utilisées pour récupérer les enregistrements.

Syntaxe

Voici la syntaxe du mode d'accès séquentiel -

ENVIRONMENT DIVISION.
INPUT-OUTPUT SECTION.
FILE-CONTROL.
   SELECT file-name ASSIGN TO dd-name
   ORGANIZATION IS SEQUENTIAL
   ACCESS MODE IS SEQUENTIAL
	
	
ENVIRONMENT DIVISION.
INPUT-OUTPUT SECTION.
   FILE-CONTROL.
   SELECT file-name ASSIGN TO dd-name
   ORGANIZATION IS INDEXED
   ACCESS MODE IS SEQUENTIAL
   RECORD KEY IS rec-key1
   ALTERNATE RECORD KEY IS rec-key2

		
ENVIRONMENT DIVISION.
INPUT-OUTPUT SECTION.
   FILE-CONTROL.
   SELECT file-name ASSIGN TO dd-name
   ORGANIZATION IS RELATIVE
   ACCESS MODE IS SEQUENTIAL
   RELATIVE KEY IS rec-key1

Accès aléatoire

Lorsque le mode d'accès est ALÉATOIRE, la méthode de récupération des enregistrements change selon l'organisation de fichiers sélectionnée.

  • Pour indexed files, les enregistrements sont accessibles en fonction de la valeur placée dans un champ clé qui peut être une clé primaire ou alternative. Il peut y avoir un ou plusieurs index alternatifs.

  • Pour relative files , les enregistrements sont récupérés via des clés d'enregistrement relatives.

Syntaxe

Voici la syntaxe du mode d'accès aléatoire -

ENVIRONMENT DIVISION.
INPUT-OUTPUT SECTION.
   FILE-CONTROL.
   SELECT file-name ASSIGN TO dd-name
   ORGANIZATION IS INDEXED
   ACCESS MODE IS RANDOM
   RECORD KEY IS rec-key1
   ALTERNATE RECORD KEY IS rec-key2

		
ENVIRONMENT DIVISION.
INPUT-OUTPUT SECTION.
   FILE-CONTROL.
   SELECT file-name ASSIGN TO dd-name
   ORGANIZATION IS RELATIVE
   ACCESS MODE IS RANDOM
   RELATIVE KEY IS rec-key1

Accès dynamique

L'accès dynamique prend en charge l'accès séquentiel et aléatoire dans le même programme. Avec l'accès dynamique, une définition de fichier est utilisée pour effectuer à la fois un traitement séquentiel et aléatoire, comme accéder à certains enregistrements dans un ordre séquentiel et à d'autres enregistrements par leurs clés.

Avec les fichiers relatifs et indexés, le mode d'accès dynamique vous permet de basculer entre le mode d'accès séquentiel et le mode d'accès aléatoire lors de la lecture d'un fichier à l'aide de la phrase NEXT sur l'instruction READ. Les fonctionnalités NEXT et READ seront discutées dans le chapitre suivant.

Syntaxe

Voici la syntaxe du mode d'accès dynamique -

ENVIRONMENT DIVISION.
INPUT-OUTPUT SECTION.
   FILE-CONTROL.
   SELECT file-name ASSIGN TO dd-name
   ORGANIZATION IS SEQUENTIAL
   ACCESS MODE IS DYNAMIC
   RECORD KEY IS rec-key1
   ALTERNATE RECORD KEY IS rec-key2

		
ENVIRONMENT DIVISION.
INPUT-OUTPUT SECTION.
   FILE-CONTROL.
   SELECT file-name ASSIGN TO dd-name
   ORGANIZATION IS RELATIVE
   ACCESS MODE IS DYNAMIC
   RELATIVE KEY IS rec-key1

Les verbes de gestion de fichiers sont utilisés pour effectuer diverses opérations sur les fichiers. Voici les verbes de gestion des fichiers -

  • Open
  • Read
  • Write
  • Rewrite
  • Delete
  • Start
  • Close

Verbe ouvert

Ouvrir est la première opération de fichier à effectuer. Si Open réussit, seules d'autres opérations sont possibles sur un fichier. Ce n'est qu'après l'ouverture d'un fichier que les variables de la structure du fichier sont disponibles pour le traitement.FILE STATUS La variable est mise à jour après chaque opération de fichier.

Syntaxe

OPEN "mode" file-name.

Ici, le nom du fichier est une chaîne littérale, que vous utiliserez pour nommer votre fichier. Un fichier peut être ouvert dans les modes suivants -

Sr.No. Mode et description
1

Input

Le mode d'entrée est utilisé pour les fichiers existants. Dans ce mode, on ne peut lire que le fichier, aucune autre opération n'est autorisée sur le fichier.

2

Output

Le mode de sortie est utilisé pour insérer des enregistrements dans des fichiers. Si unsequential fileest utilisé et le fichier contient des enregistrements, les enregistrements existants seront d'abord supprimés, puis de nouveaux enregistrements seront insérés dans le fichier. Cela ne se produira pas ainsi en cas deindexed file ou un relative file.

3

Extend

Le mode étendu est utilisé pour ajouter des enregistrements dans un sequential file. Dans ce mode, les enregistrements sont insérés à la fin. Si le mode d'accès aux fichiers estRandom ou Dynamic, le mode d'extension ne peut pas être utilisé.

4

I-O

Le mode d'entrée-sortie est utilisé pour lire et réécrire les enregistrements d'un fichier.

Lire le verbe

Le verbe de lecture est utilisé pour lire les enregistrements du fichier. La fonction de lecture est de récupérer les enregistrements d'un fichier. À chaque verbe de lecture, un seul enregistrement peut être lu dans la structure de fichier. Pour effectuer une opération de lecture, ouvrez le fichier en mode INPUT ou IO. A chaque instruction de lecture, le pointeur de fichier est incrémenté et donc les enregistrements successifs sont lus.

Syntaxe

Voici la syntaxe pour lire les enregistrements lorsque le mode d'accès aux fichiers est séquentiel -

READ file-name NEXT RECORD INTO ws-file-structure
   AT END DISPLAY 'End of File'
   NOT AT END DISPLAY 'Record Details:' ws-file-structure
END-READ.

Voici les paramètres utilisés -

  • NEXT RECORD est facultatif et est spécifié lorsqu'un fichier séquentiel indexé est lu séquentiellement.

  • La clause INTO est facultative. ws-file-structure est défini dans la section WorkingStorage pour obtenir les valeurs de l'instruction READ.

  • La condition AT END devient True lorsque la fin du fichier est atteinte.

Example- L'exemple suivant lit un fichier existant en utilisant l'organisation séquentielle de ligne. Ce programme peut être compilé et exécuté en utilisantLive Demo option où il affichera tous les enregistrements présents dans le fichier.

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.

ENVIRONMENT DIVISION.
   INPUT-OUTPUT SECTION.
      FILE-CONTROL.
      SELECT STUDENT ASSIGN TO 'input.txt'
      ORGANIZATION IS LINE SEQUENTIAL.            

DATA DIVISION.
   FILE SECTION.
   FD STUDENT.
   01 STUDENT-FILE.
      05 STUDENT-ID PIC 9(5).
      05 NAME PIC A(25).

   WORKING-STORAGE SECTION.
   01 WS-STUDENT.
      05 WS-STUDENT-ID PIC 9(5).
      05 WS-NAME PIC A(25).
   01 WS-EOF PIC A(1). 

PROCEDURE DIVISION.
   OPEN INPUT STUDENT.
      PERFORM UNTIL WS-EOF='Y'
         READ STUDENT INTO WS-STUDENT
            AT END MOVE 'Y' TO WS-EOF
            NOT AT END DISPLAY WS-STUDENT
         END-READ
      END-PERFORM.
   CLOSE STUDENT.
STOP RUN.

Supposons que les données du fichier d'entrée disponibles dans le input.txt le fichier contient les éléments suivants -

20003 Mohtashim M.
20004 Nishant Malik
20005 Amitabh Bachhan

Lorsque vous compilez et exécutez le programme ci-dessus, il produit le résultat suivant -

20003 Mohtashim M.            
20004 Nishant Malik           
20005 Amitabh Bachhan

Syntaxe

Voici la syntaxe pour lire un enregistrement lorsque le mode d'accès au fichier est aléatoire -

READ file-name RECORD INTO ws-file-structure
   KEY IS rec-key
   INVALID KEY DISPLAY 'Invalid Key'
   NOT INVALID KEY DISPLAY 'Record Details: ' ws-file-structure
END-READ.

Example- L'exemple suivant lit un fichier existant à l'aide d'une organisation indexée. Ce programme peut être compilé et exécuté en utilisantJCLsur les Mainframes où il affichera tous les enregistrements présents dans le fichier. Sur le serveur Mainframes, nous n'utilisons pas de fichiers texte; à la place, nous utilisons des fichiers PS.

Supposons que le fichier présent sur les Mainframes ait le même contenu que le fichier input.txt dans l'exemple ci-dessus.

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.

ENVIRONMENT DIVISION.
   INPUT-OUTPUT SECTION.
   FILE-CONTROL.
   SELECT STUDENT ASSIGN TO IN1
      ORGANIZATION IS INDEXED
      ACCESS IS RANDOM
      RECORD KEY IS STUDENT-ID
      FILE STATUS IS FS.

DATA DIVISION.
   FILE SECTION.
   FD STUDENT.
      01 STUDENT-FILE.
      05 STUDENT-ID PIC 9(5).
      05 NAME PIC A(25).
     
   WORKING-STORAGE SECTION.
   01 WS-STUDENT.
      05 WS-STUDENT-ID PIC 9(5).
      05 WS-NAME PIC A(25).

PROCEDURE DIVISION.
   OPEN INPUT STUDENT.
      MOVE 20005 TO STUDENT-ID.
      
      READ STUDENT RECORD INTO WS-STUDENT-FILE
         KEY IS STUDENT-ID
         INVALID KEY DISPLAY 'Invalid Key'
         NOT INVALID KEY DISPLAY WS-STUDENT-FILE
      END-READ.
      
   CLOSE STUDENT.
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 = STUDENT-FILE-NAME,DISP=SHR

Lorsque vous compilez et exécutez le programme ci-dessus, il produit le résultat suivant -

20005 Amitabh Bachhan

Écrire un verbe

Le verbe Write est utilisé pour insérer des enregistrements dans un fichier. Une fois l'enregistrement écrit, il n'est plus disponible dans le tampon d'enregistrement. Avant d'insérer des enregistrements dans le fichier, déplacez les valeurs dans le tampon d'enregistrement, puis effectuez un verbe d'écriture.

L'instruction d'écriture peut être utilisée avec FROMoption pour écrire directement des enregistrements à partir des variables de stockage de travail. From est une clause facultative. Si le mode d'accès est séquentiel, alors pour écrire un enregistrement, le fichier doit s'ouvrir en mode Sortie ou en mode Extension. Si le mode d'accès est aléatoire ou dynamique, alors pour écrire un enregistrement, le fichier doit s'ouvrir en mode Sortie ou en mode IO.

Syntaxe

Voici la syntaxe pour lire un enregistrement lorsque l'organisation du fichier est séquentielle -

WRITE record-buffer [FROM ws-file-structure]
END-WRITE.

Voici la syntaxe pour lire un enregistrement lorsque l'organisation du fichier est indexée ou relative -

WRITE record-buffer [FROM ws-file-structure]
   INVALID KEY DISPLAY 'Invalid Key'
   NOT INVALID KEY DISPLAY 'Record Inserted'
END-WRITE.

Example - L'exemple suivant montre comment insérer un nouvel enregistrement dans un nouveau fichier lorsque l'organisation est séquentielle.

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.

ENVIRONMENT DIVISION.
   INPUT-OUTPUT SECTION.
   FILE-CONTROL.
   SELECT STUDENT ASSIGN TO OUT1
      ORGANIZATION IS SEQUENTIAL
      ACCESS IS SEQUENTIAL
      FILE STATUS IS FS.

DATA DIVISION.
   FILE SECTION.
   FD STUDENT
   01 STUDENT-FILE.
      05 STUDENT-ID PIC 9(5).
      05 NAME PIC A(25).
      05 CLASS PIC X(3).

   WORKING-STORAGE SECTION.
   01 WS-STUDENT.
      05 WS-STUDENT-ID PIC 9(5).
      05 WS-NAME PIC A(25).
      05 WS-CLASS PIC X(3).

PROCEDURE DIVISION.
   OPEN EXTEND STUDENT.
      MOVE 1000 TO STUDENT-ID.
      MOVE 'Tim' TO NAME.
      MOVE '10' TO CLASS.
      WRITE STUDENT-FILE
      END-WRITE.	
   CLOSE STUDENT.
STOP RUN.

JCL pour exécuter le programme COBOL ci-dessus -

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO
//OUT1 DD DSN = OUTPUT-FILE-NAME,DISP = (NEW,CATALOG,DELETE)

Lorsque vous compilez et exécutez le programme ci-dessus, il ajoutera un nouvel enregistrement au fichier de sortie.

1000 Tim         10

Réécrire le verbe

Le verbe de réécriture est utilisé pour mettre à jour les enregistrements. Le fichier doit être ouvert en mode IO pour les opérations de réécriture. Il ne peut être utilisé qu'après une opération de lecture réussie. Le verbe de réécriture écrase le dernier enregistrement lu.

Syntaxe

Voici la syntaxe pour lire un enregistrement lorsque l'organisation du fichier est séquentielle -

REWRITE record-buffer [FROM ws-file-structure]
END-REWRITE.

Voici la syntaxe pour lire un enregistrement lorsque l'organisation du fichier est indexée ou relative -

REWRITE record-buffer [FROM ws-file-structure]
   INVALID KEY DISPLAY 'Invalid Key'
   NOT INVALID KEY DISPLAY 'Record Updated'
END-REWRITE.

Example - L'exemple suivant montre comment mettre à jour un enregistrement existant que nous avons inséré à l'étape d'écriture précédente -

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.

ENVIRONMENT DIVISION.
   INPUT-OUTPUT SECTION.
   FILE-CONTROL.
   SELECT STUDENT ASSIGN TO IN1
      ORGANIZATION IS INDEXED
      ACCESS IS RANDOM
      RECORD KEY IS STUDENT-ID
      FILE STATUS IS FS.

DATA DIVISION.
   FILE SECTION.
   FD STUDENT
   01 STUDENT-FILE.
      05 STUDENT-ID PIC 9(4).
      05 NAME PIC A(12).
      05 CLASS PIC X(3).
      
   WORKING-STORAGE SECTION.
   01 WS-STUDENT.
      05 WS-STUDENT-ID PIC 9(5).
      05 WS-NAME PIC A(25).
      05 WS-CLASS PIC X(3).

PROCEDURE DIVISION.
   OPEN I-O STUDENT.
   MOVE '1000' TO STUDENT-ID.
  
   READ STUDENT
      KEY IS STUDENT-ID
      INVALID KEY DISPLAY ‘KEY IS NOT EXISTING’
   END-READ.
  
   MOVE 'Tim Dumais' TO NAME.
   REWRITE STUDENT-FILE
   END-REWRITE.
   CLOSE STUDENT.
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 = OUTPUT-FILE-NAME,DISP = SHR

Lorsque vous compilez et exécutez le programme ci-dessus, il mettra à jour l'enregistrement -

1000 Tim Dumais  10

Supprimer le verbe

Le verbe de suppression ne peut être exécuté que sur les fichiers indexés et relatifs. Le fichier doit être ouvert en mode IO. Dans l'organisation séquentielle des fichiers, les enregistrements ne peuvent pas être supprimés. Le dernier enregistrement lu par l'instruction Read est supprimé en cas d'accès séquentiel. En mode d'accès aléatoire, spécifiez la clé d'enregistrement, puis effectuez l'opération de suppression.

Syntaxe

Voici la syntaxe pour supprimer un enregistrement -

DELETE file-name RECORD
   INVALID KEY DISPLAY 'Invalid Key'
   NOT INVALID KEY DISPLAY 'Record Deleted'
END-DELETE.

Example - pour supprimer un enregistrement existant -

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.

ENVIRONMENT DIVISION.
   INPUT-OUTPUT SECTION.
   FILE-CONTROL.
   SELECT STUDENT ASSIGN TO OUT1
      ORGANIZATION IS INDEXED
      ACCESS IS RANDOM
      RECORD KEY IS STUDENT-ID
      FILE STATUS IS FS.

DATA DIVISION.
   FILE SECTION.
   FD STUDENT
   01 STUDENT-FILE.
      05 STUDENT-ID PIC 9(4).
      05 NAME PIC A(12).
      05 CLASS PIC X(3).
   WORKING-STORAGE SECTION.
   01 WS-STUDENT.
      05 WS-STUDENT-ID PIC 9(5).
      05 WS-NAME PIC A(25).
      05 WS-CLASS PIC X(3).

PROCEDURE DIVISION.
   OPEN I-O STUDENT.
   MOVE '1000' TO STUDENT-ID.
   
   DELETE STUDENT RECORD
      INVALID KEY DISPLAY 'Invalid Key'
      NOT INVALID KEY DISPLAY 'Record Deleted'
   END-DELETE.
   
   CLOSE STUDENT.
STOP RUN.

JCL pour exécuter le programme COBOL ci-dessus -

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = HELLO
//OUT1 DD DSN = OUTPUT-FILE-NAME,DISP = SHR

Lorsque vous compilez et exécutez le programme ci-dessus, il produit le résultat suivant -

Record Deleted

Démarrer le verbe

Le verbe de démarrage ne peut être exécuté que sur les fichiers indexés et relatifs. Il est utilisé pour placer le pointeur de fichier sur un enregistrement spécifique. Le mode d'accès doit être séquentiel ou dynamique. Le fichier doit être ouvert en mode IO ou Input.

Syntaxe

Voici la syntaxe pour placer le pointeur sur un enregistrement spécifique -

START file-name KEY IS [=, >, <, NOT, <= or >=] rec-key
   INVALID KEY DISPLAY 'Invalid Key'
   NOT INVALID KEY DISPLAY 'File Pointer Updated'
END-START.

Fermer le verbe

Le verbe Close est utilisé pour fermer un fichier. Après avoir effectué l'opération de fermeture, les variables de la structure de fichier ne seront pas disponibles pour le traitement. Le lien entre le programme et le fichier est perdu.

Syntaxe

Voici la syntaxe pour fermer un fichier -

CLOSE file-name.

Le sous-programme Cobol est un programme qui peut être compilé indépendamment mais ne peut pas être exécuté indépendamment. Il existe deux types de sous-programmes:internal subroutines comme Perform déclarations et external des sous-programmes comme le verbe CALL.

Verbe d'appel

Le verbe d'appel est utilisé pour transférer le contrôle d'un programme à un autre programme. Le programme qui contient le verbe CALL est leCalling Program et le programme appelé est appelé Called Program. L'exécution du programme appelant s'arrêtera jusqu'à ce que le programme appelé termine l'exécution. L'instruction Exit Program est utilisée dans le programme Called pour retransférer le contrôle.

Contraintes de programme appelées

Voici les exigences du programme appelé -

  • Linkage sectiondoit être défini dans le programme appelé. Il se compose d'éléments de données passés dans le programme. Les éléments de données ne doivent pas avoir de clause Value. La clause PIC doit être compatible avec les variables transmises via le programme appelant.

  • Procedure division using a une liste de variables transmises par le programme appelant et l'ordre doit être le même que celui mentionné dans le verbe Call.

  • Exit programl'instruction est utilisée dans le programme appelé pour retransférer le contrôle. Ce doit être la dernière instruction du programme appelé.

Les paramètres peuvent être passés entre les programmes de deux manières -

  • Par référence
  • Par contenu

Appel par référence

Si les valeurs des variables dans le programme appelé sont modifiées, alors leurs nouvelles valeurs seront reflétées dans le programme appelant. SiBY clause n'est pas spécifiée, les variables sont toujours passées par référence.

Syntaxe

Voici la syntaxe de l'appel du sous-programme par référence -

CALL sub-prog-name USING variable-1, variable-2.

Example

L'exemple suivant est le programme appelant MAIN et UTIL est le programme appelé -

IDENTIFICATION DIVISION.
PROGRAM-ID. MAIN.

DATA DIVISION.
   WORKING-STORAGE SECTION.
   01 WS-STUDENT-ID PIC 9(4) VALUE 1000.
   01 WS-STUDENT-NAME PIC A(15) VALUE 'Tim'.

PROCEDURE DIVISION.
   CALL 'UTIL' USING WS-STUDENT-ID, WS-STUDENT-NAME.
   DISPLAY 'Student Id : ' WS-STUDENT-ID
   DISPLAY 'Student Name : ' WS-STUDENT-NAME
STOP RUN.

Programme appelé

IDENTIFICATION DIVISION.
PROGRAM-ID. UTIL.

DATA DIVISION.
   LINKAGE SECTION.
   01 LS-STUDENT-ID PIC 9(4).
   01 LS-STUDENT-NAME PIC A(15).

PROCEDURE DIVISION USING LS-STUDENT-ID, LS-STUDENT-NAME.
   DISPLAY 'In Called Program'.
   MOVE 1111 TO LS-STUDENT-ID.
EXIT PROGRAM.

JCL pour exécuter le programme COBOL ci-dessus -

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = MAIN

Lorsque vous compilez et exécutez le programme ci-dessus, il produit le résultat suivant -

In Called Program
Student Id : 1111
Student Name : Tim

Appel par contenu

Si les valeurs des variables dans le programme appelé sont modifiées, leurs nouvelles valeurs ne seront pas reflétées dans le programme appelant.

Syntaxe

Voici la syntaxe de l'appel du sous-programme par contenu -

CALL sub-prog-name USING 
BY CONTENT variable-1, BY CONTENT variable-2.

Example

L'exemple suivant est le programme appelant MAIN et UTIL est le programme appelé -

IDENTIFICATION DIVISION.
PROGRAM-ID. MAIN.

DATA DIVISION.
   WORKING-STORAGE SECTION.
   01 WS-STUDENT-ID PIC 9(4) VALUE 1000.
   01 WS-STUDENT-NAME PIC A(15) VALUE 'Tim'.

PROCEDURE DIVISION.
   CALL 'UTIL' USING BY CONTENT WS-STUDENT-ID, BY CONTENT WS-STUDENT-NAME.
   DISPLAY 'Student Id : ' WS-STUDENT-ID
   DISPLAY 'Student Name : ' WS-STUDENT-NAME
STOP RUN.

Programme appelé

IDENTIFICATION DIVISION.
PROGRAM-ID. UTIL.

DATA DIVISION.
   LINKAGE SECTION.
   01 LS-STUDENT-ID PIC 9(4).
   01 LS-STUDENT-NAME PIC A(15).

PROCEDURE DIVISION USING LS-STUDENT-ID, LS-STUDENT-NAME.
   DISPLAY 'In Called Program'.
   MOVE 1111 TO LS-STUDENT-ID.
EXIT PROGRAM.

JCL pour exécuter le programme COBOL ci-dessus -

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1 EXEC PGM = MAIN

Lorsque vous compilez et exécutez le programme ci-dessus, il produit le résultat suivant -

In Called Program
Student Id : 1000
Student Name : Tim

Types d'appel

Il existe deux types d'appels -

  • Static Callse produit lorsqu'un programme est compilé avec l'option de compilateur NODYNAM. Un programme appelé statique est chargé dans le stockage au moment de la compilation.

  • Dynamic Callse produit lorsqu'un programme est compilé avec l'option de compilateur DYNAM et NODLL. Un programme appelé dynamique est chargé dans le stockage au moment de l'exécution.

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

À partir de maintenant, nous avons appris l'utilisation des fichiers en COBOL. Nous allons maintenant discuter de la manière dont un programme COBOL interagit avec DB2. Cela implique les termes suivants -

  • SQL embarqué
  • Programmation d'application DB2
  • Variables d'hôte
  • SQLCA
  • Requêtes SQL
  • Cursors

SQL embarqué

Les instructions SQL intégrées sont utilisées dans les programmes COBOL pour effectuer des opérations SQL standard. Les instructions SQL intégrées sont prétraitées par le processeur SQL avant la compilation du programme d'application. COBOL est connu comme leHost Language. Les applications COBOL-DB2 sont les applications qui incluent à la fois COBOL et DB2.

Les instructions SQL intégrées fonctionnent comme des instructions SQL normales avec quelques modifications mineures. Par exemple, la sortie d'une requête est dirigée vers un ensemble prédéfini de variables appeléesHost Variables. Une clause INTO supplémentaire est placée dans l'instruction SELECT.

Programmation d'application DB2

Voici les règles à suivre lors du codage d'un programme COBOL-DB2 -

  • Toutes les instructions SQL doivent être délimitées entre EXEC SQL et ENDEXEC..

  • Les instructions SQL doivent être codées dans la zone B.

  • Toutes les tables utilisées dans un programme doivent être déclarées dans la section WorkingStorage. Cela se fait en utilisant leINCLUDE déclaration.

  • Toutes les instructions SQL autres que INCLUDE et DECLARE TABLE doivent apparaître dans la section Procédure.

Variables d'hôte

Les variables hôtes sont utilisées pour recevoir des données d'une table ou insérer des données dans une table. Les variables hôte doivent être déclarées pour toutes les valeurs à transmettre entre le programme et le DB2. Ils sont déclarés dans la section Working-Storage.

Les variables hôtes ne peuvent pas être des éléments de groupe, mais elles peuvent être regroupées dans une structure hôte. Ils ne peuvent pas êtreRenamed ou Redefined. En utilisant des variables hôtes avec des instructions SQL, préfixez-les avec uncolon (:)..

Syntaxe

Voici la syntaxe pour déclarer les variables hôtes et inclure des tables dans la section Working-Storage -

DATA DIVISION.
   WORKING-STORAGE SECTION.
   
   EXEC SQL
   INCLUDE table-name
   END-EXEC.

   EXEC SQL BEGIN DECLARE SECTION
   END-EXEC.
   
   01 STUDENT-REC.
      05 STUDENT-ID PIC 9(4).
      05 STUDENT-NAME PIC X(25).
      05 STUDENT-ADDRESS X(50).
   EXEC SQL END DECLARE SECTION
   END-EXEC.

SQLCA

SQLCA est une zone de communication SQL à travers laquelle DB2 transmet le retour de l'exécution SQL au programme. Il indique au programme si une exécution a réussi ou non. Il existe un certain nombre de variables prédéfinies sous SQLCA commeSQLCODEqui contient le code d'erreur. La valeur «000» dans SQLCODE indique une exécution réussie.

Syntaxe

Voici la syntaxe pour déclarer un SQLCA dans la section Working-Storage -

DATA DIVISION.
WORKING-STORAGE SECTION.
	EXEC SQL
	INCLUDE SQLCA
	END-EXEC.

Requêtes SQL

Supposons que nous ayons une table nommée «Student» qui contient Student-Id, Student-Name et Student-Address.

Le tableau STUDENT contient les données suivantes -

Student Id		Student Name		Student Address
1001 			   Mohtashim M.		Hyderabad
1002			   Nishant Malik		Delhi
1003 			   Amitabh Bachan		Mumbai
1004			   Chulbul Pandey		Lucknow

L'exemple suivant montre l'utilisation de SELECT requête dans un programme COBOL -

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.

DATA DIVISION.
   WORKING-STORAGE SECTION.
   EXEC SQL
      INCLUDE SQLCA
   END-EXEC.
   
   EXEC SQL
      INCLUDE STUDENT
   END-EXEC.
   
   EXEC SQL BEGIN DECLARE SECTION
   END-EXEC.
      01 WS-STUDENT-REC.
         05 WS-STUDENT-ID PIC 9(4).
         05 WS-STUDENT-NAME PIC X(25).
         05 WS-STUDENT-ADDRESS X(50).
   EXEC SQL END DECLARE SECTION
   END-EXEC.

PROCEDURE DIVISION.
   EXEC SQL
      SELECT STUDENT-ID, STUDENT-NAME, STUDENT-ADDRESS
      INTO :WS-STUDENT-ID, :WS-STUDENT-NAME, WS-STUDENT-ADDRESS FROM STUDENT
      WHERE STUDENT-ID=1004
   END-EXEC.
   
   IF SQLCODE = 0 
      DISPLAY WS-STUDENT-RECORD
   ELSE DISPLAY 'Error'
   END-IF.
STOP RUN.

JCL pour exécuter le programme COBOL ci-dessus -

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP001  EXEC PGM = IKJEFT01
//STEPLIB  DD DSN = MYDATA.URMI.DBRMLIB,DISP = SHR
//SYSPRINT DD SYSOUT=*
//SYSUDUMP DD SYSOUT=*
//SYSOUT   DD SYSOUT=*
//SYSTSIN  DD *
   DSN SYSTEM(SSID)
   RUN PROGRAM(HELLO) PLAN(PLANNAME) -
   END
/*

Lorsque vous compilez et exécutez le programme ci-dessus, il produit le résultat suivant -

1004 Chulbul Pandey		Lucknow

L'exemple suivant montre l'utilisation de INSERT requête dans un programme COBOL -

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.

DATA DIVISION.
   WORKING-STORAGE SECTION.
   EXEC SQL
   INCLUDE SQLCA
   END-EXEC.
   
   EXEC SQL
   INCLUDE STUDENT
   END-EXEC.
   
   EXEC SQL BEGIN DECLARE SECTION
   END-EXEC.
      01 WS-STUDENT-REC.
         05 WS-STUDENT-ID PIC 9(4).
         05 WS-STUDENT-NAME PIC X(25).
         05 WS-STUDENT-ADDRESS X(50).
   EXEC SQL END DECLARE SECTION
   END-EXEC.

PROCEDURE DIVISION.
   MOVE 1005 TO WS-STUDENT-ID.
   MOVE 'TutorialsPoint' TO WS-STUDENT-NAME.
   MOVE 'Hyderabad' TO WS-STUDENT-ADDRESS.
   
   EXEC SQL
      INSERT INTO STUDENT(STUDENT-ID, STUDENT-NAME, STUDENT-ADDRESS)
      VALUES (:WS-STUDENT-ID, :WS-STUDENT-NAME, WS-STUDENT-ADDRESS)
   END-EXEC.
   
   IF SQLCODE = 0 
      DISPLAY 'Record Inserted Successfully'
      DISPLAY WS-STUDENT-REC
   ELSE DISPLAY 'Error'
   END-IF.
STOP RUN.

JCL pour exécuter le programme COBOL ci-dessus -

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP001  EXEC PGM = IKJEFT01
//STEPLIB  DD DSN = MYDATA.URMI.DBRMLIB,DISP=SHR
//SYSPRINT DD SYSOUT = *
//SYSUDUMP DD SYSOUT = *
//SYSOUT   DD SYSOUT = *
//SYSTSIN  DD *
   DSN SYSTEM(SSID)
   RUN PROGRAM(HELLO) PLAN(PLANNAME) -
   END
/*

Lorsque vous compilez et exécutez le programme ci-dessus, il produit le résultat suivant -

Record Inserted Successfully
1005 TutorialsPoint		Hyderabad

L'exemple suivant montre l'utilisation de UPDATE requête dans un programme COBOL -

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.

DATA DIVISION.
   WORKING-STORAGE SECTION.
   
   EXEC SQL
   INCLUDE SQLCA
   END-EXEC.
   
   EXEC SQL
   INCLUDE STUDENT
   END-EXEC.
   
   EXEC SQL BEGIN DECLARE SECTION
   END-EXEC.
      01 WS-STUDENT-REC.
         05 WS-STUDENT-ID PIC 9(4).
         05 WS-STUDENT-NAME PIC X(25).
         05 WS-STUDENT-ADDRESS X(50).
   EXEC SQL END DECLARE SECTION
   END-EXEC.

PROCEDURE DIVISION.
   MOVE 'Bangalore' TO WS-STUDENT-ADDRESS.
   EXEC SQL
      UPDATE STUDENT SET STUDENT-ADDRESS=:WS-STUDENT-ADDRESS
      WHERE STUDENT-ID = 1003
   END-EXEC.
   
   IF SQLCODE = 0 
      DISPLAY 'Record Updated Successfully'
   ELSE DISPLAY 'Error'
   END-IF.
STOP RUN.

JCL pour exécuter le programme COBOL ci-dessus -

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP001  EXEC PGM = IKJEFT01
//STEPLIB  DD DSN = MYDATA.URMI.DBRMLIB,DISP = SHR
//SYSPRINT DD SYSOUT = *
//SYSUDUMP DD SYSOUT = *
//SYSOUT   DD SYSOUT = *
//SYSTSIN  DD *
   DSN SYSTEM(SSID)
   RUN PROGRAM(HELLO) PLAN(PLANNAME) -
   END
/*

Lorsque vous compilez et exécutez le programme ci-dessus, il produit le résultat suivant -

Record Updated Successfully

Le suivant example montre l'utilisation de DELETE requête dans un programme COBOL -

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.

DATA DIVISION.
WORKING-STORAGE SECTION.

   EXEC SQL
   INCLUDE SQLCA
   END-EXEC.
   
   EXEC SQL
   INCLUDE STUDENT
   END-EXEC.
   
   EXEC SQL BEGIN DECLARE SECTION
   END-EXEC.
      01 WS-STUDENT-REC.
         05 WS-STUDENT-ID PIC 9(4).
         05 WS-STUDENT-NAME PIC X(25).
         05 WS-STUDENT-ADDRESS X(50).
   EXEC SQL END DECLARE SECTION
   END-EXEC.

PROCEDURE DIVISION.
   MOVE 1005 TO WS-STUDENT-ID.
   
   EXEC SQL
      DELETE FROM STUDENT
      WHERE STUDENT-ID=:WS-STUDENT-ID
   END-EXEC.
   
   IF SQLCODE = 0 
      DISPLAY 'Record Deleted Successfully'
   ELSE DISPLAY 'Error'
   END-IF.
STOP RUN.

JCL pour exécuter le programme COBOL ci-dessus -

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP001  EXEC PGM = IKJEFT01
//STEPLIB  DD DSN = MYDATA.URMI.DBRMLIB,DISP=SHR
//SYSPRINT DD SYSOUT = *
//SYSUDUMP DD SYSOUT = *
//SYSOUT   DD SYSOUT = *
//SYSTSIN  DD *
   DSN SYSTEM(SSID)
   RUN PROGRAM(HELLO) PLAN(PLANNAME) -
   END
/*

Lorsque vous compilez et exécutez le programme ci-dessus, il produit le résultat suivant -

Record Deleted Successfully

Curseurs

Les curseurs sont utilisés pour gérer plusieurs sélections de lignes à la fois. Ce sont des structures de données qui contiennent tous les résultats d'une requête. Ils peuvent être définis dans la section Travail-Stockage ou dans la Division Procédure. Voici les opérations associées au curseur -

  • Declare
  • Open
  • Close
  • Fetch

Déclarer le curseur

La déclaration du curseur peut être effectuée dans la section de stockage de travail ou la division de procédure. La première instruction est l'instruction DECLARE qui est une instruction non exécutable.

EXEC SQL
   DECLARE STUDCUR CURSOR FOR
   SELECT STUDENT-ID, STUDENT-NAME, STUDENT-ADDRESS FROM STUDENT
   WHERE STUDENT-ID >:WS-STUDENT-ID
END-EXEC.

Ouvert

Avant d'utiliser un curseur, l'instruction Open doit être exécutée. L'instruction Open prépare le SELECT pour l'exécution.

EXEC SQL
   OPEN STUDCUR
END-EXEC.

Fermer

L'instruction Close libère toute la mémoire occupée par le curseur. Il est obligatoire de fermer un curseur avant de terminer un programme.

EXEC SQL
   CLOSE STUDCUR
END-EXEC.

Récupérer

L'instruction Fetch identifie le curseur et place la valeur dans la clause INTO. Une instruction Fetch est codée en boucle lorsque nous obtenons une ligne à la fois.

EXEC SQL
   FETCH STUDCUR
   INTO :WS-STUDENT-ID, :WS-STUDENT-NAME, WS-STUDENT-ADDRESS
END-EXEC.

L'exemple suivant montre l'utilisation du curseur pour récupérer tous les enregistrements de la table STUDENT -

IDENTIFICATION DIVISION.
PROGRAM-ID. HELLO.

DATA DIVISION.
   WORKING-STORAGE SECTION.
   
   EXEC SQL
   INCLUDE SQLCA
   END-EXEC.
   
   EXEC SQL
   INCLUDE STUDENT
   END-EXEC.
   
   EXEC SQL BEGIN DECLARE SECTION
   END-EXEC.
      01 WS-STUDENT-REC.
         05 WS-STUDENT-ID PIC 9(4).
         05 WS-STUDENT-NAME PIC X(25).
         05 WS-STUDENT-ADDRESS X(50).
   EXEC SQL END DECLARE SECTION
   END-EXEC.
   
   EXEC SQL
      DECLARE STUDCUR CURSOR FOR
      SELECT STUDENT-ID, STUDENT-NAME, STUDENT-ADDRESS FROM STUDENT
      WHERE STUDENT-ID >:WS-STUDENT-ID
   END-EXEC.

PROCEDURE DIVISION.
   MOVE 1001 TO WS-STUDENT-ID.
   PERFORM UNTIL SQLCODE = 100
   
   EXEC SQL
      FETCH STUDCUR
      INTO :WS-STUDENT-ID, :WS-STUDENT-NAME, WS-STUDENT-ADDRESS
   END-EXEC
   
   DISPLAY WS-STUDENT-REC
END-PERFORM	
STOP RUN.

JCL pour exécuter le programme COBOL ci-dessus -

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP001  EXEC PGM=IKJEFT01
//STEPLIB  DD DSN=MYDATA.URMI.DBRMLIB,DISP=SHR
//SYSPRINT DD SYSOUT=*
//SYSUDUMP DD SYSOUT=*
//SYSOUT   DD SYSOUT=*
//SYSTSIN  DD *
   DSN SYSTEM(SSID)
   RUN PROGRAM(HELLO) PLAN(PLANNAME) -
   END
/*

Lorsque vous compilez et exécutez le programme ci-dessus, il produit le résultat suivant -

1001 Mohtashim M.		Hyderabad
1002 Nishant Malik		Delhi
1003 Amitabh Bachan		Mumbai
1004 Chulbul Pandey		Lucknow