IMS DB - Guide rapide
Un bref aperçu
La base de données est une collection d'éléments de données corrélés. Ces éléments de données sont organisés et stockés de manière à fournir un accès rapide et facile. La base de données IMS est une base de données hiérarchique dans laquelle les données sont stockées à différents niveaux et chaque entité dépend d'entités de niveau supérieur. Les éléments physiques d'un système d'application utilisant IMS sont illustrés dans la figure suivante.
Gestion de base de données
Un système de gestion de base de données est un ensemble de programmes d'application utilisés pour stocker, accéder et gérer des données dans la base de données. Le système de gestion de base de données IMS maintient l'intégrité et permet une récupération rapide des données en les organisant de manière à ce qu'elles soient faciles à récupérer. IMS gère une grande quantité de données d'entreprise dans le monde à l'aide de son système de gestion de base de données.
Gestionnaire de transactions
La fonction du gestionnaire de transactions est de fournir une plate-forme de communication entre la base de données et les programmes d'application. IMS agit en tant que gestionnaire de transactions. Un gestionnaire de transactions traite avec l'utilisateur final pour stocker et récupérer les données de la base de données. IMS peut utiliser IMS DB ou DB2 comme base de données principale pour stocker les données.
DL / I - Interface de langage de données
DL / I comprend des programmes d'application qui permettent d'accéder aux données stockées dans la base de données. IMS DB utilise DL / I qui sert de langage d'interface que les programmeurs utilisent pour accéder à la base de données dans un programme d'application. Nous en discuterons plus en détail dans les prochains chapitres.
Caractéristiques de l'IMS
Points à noter -
- IMS prend en charge les applications de différents langages tels que Java et XML.
- Les applications et les données IMS sont accessibles sur n'importe quelle plateforme.
- Le traitement IMS DB est très rapide par rapport à DB2.
Limitations d'IMS
Points à noter -
- La mise en œuvre d'IMS DB est très complexe.
- L'arborescence prédéfinie par IMS réduit la flexibilité.
- IMS DB est difficile à gérer.
Structure hiérarchique
Une base de données IMS est une collection de données contenant des fichiers physiques. Dans une base de données hiérarchique, le niveau le plus élevé contient les informations générales sur l'entité. Au fur et à mesure que nous passons du niveau supérieur aux niveaux inférieurs de la hiérarchie, nous obtenons de plus en plus d'informations sur l'entité.
Chaque niveau de la hiérarchie contient des segments. Dans les fichiers standard, il est difficile d'implémenter des hiérarchies mais DL / I prend en charge les hiérarchies. La figure suivante illustre la structure d'IMS DB.
Segment
Points à noter -
Un segment est créé en regroupant des données similaires.
Il s'agit de la plus petite unité d'information que DL / I transfère vers et depuis un programme d'application pendant toute opération d'entrée-sortie.
Un segment peut avoir un ou plusieurs champs de données regroupés.
Dans l'exemple suivant, le segment Student comporte quatre champs de données.
Étudiant | |||
---|---|---|---|
Numéro de rôle | Nom | Cours | Numéro de portable |
Champ
Points à noter -
Un champ est une seule donnée dans un segment. Par exemple, le numéro de rôle, le nom, le cours et le numéro de mobile sont des champs uniques dans le segment étudiant.
Un segment se compose de champs associés pour collecter les informations d'une entité.
Les champs peuvent être utilisés comme clé pour classer les segments.
Les champs peuvent être utilisés comme qualificatif pour rechercher des informations sur un segment particulier.
Type de segment
Points à noter -
Le type de segment est une catégorie de données dans un segment.
Une base de données DL / I peut avoir 255 types de segments différents et 15 niveaux de hiérarchie.
Dans la figure suivante, il y a trois segments à savoir, Bibliothèque, Informations sur les livres et Informations sur les étudiants.
Occurrence de segment
Points à noter -
Une occurrence de segment est un segment individuel d'un type particulier contenant des données utilisateur. Dans l'exemple ci-dessus, Informations sur les livres est un type de segment et il peut y avoir un nombre quelconque d'occurrences, car il peut stocker les informations sur un nombre illimité de livres.
Dans la base de données IMS, il n'y a qu'une seule occurrence de chaque type de segment, mais il peut y avoir un nombre illimité d'occurrences de chaque type de segment.
Les bases de données hiérarchiques fonctionnent sur les relations entre deux ou plusieurs segments. L'exemple suivant montre comment les segments sont liés les uns aux autres dans la structure de la base de données IMS.
Segment racine
Points à noter -
Le segment qui se trouve en haut de la hiérarchie est appelé le segment racine.
Le segment racine est le seul segment par lequel tous les segments dépendants sont accessibles.
Le segment racine est le seul segment de la base de données qui n'est jamais un segment enfant.
Il ne peut y avoir qu'un seul segment racine dans la structure de la base de données IMS.
Par exemple, 'A' est le segment racine dans l'exemple ci-dessus.
Segment parent
Points à noter -
Un segment parent a un ou plusieurs segments dépendants directement en dessous.
Par exemple, 'A', 'B', et 'E' sont les segments parents dans l'exemple ci-dessus.
Segment dépendant
Points à noter -
Tous les segments autres que le segment racine sont appelés segments dépendants.
Les segments dépendants dépendent d'un ou plusieurs segments pour présenter une signification complète.
Par exemple, 'B', 'C1', 'C2', 'D', 'E', 'F1' et 'F2' sont des segments dépendants dans notre exemple.
Segment enfant
Points à noter -
Tout segment ayant un segment directement au-dessus de lui dans la hiérarchie est appelé segment enfant.
Chaque segment dépendant de la structure est un segment enfant.
Par exemple, 'B', 'C1', 'C2', 'D', 'E', 'F1' et 'F2' sont des segments enfants.
Segments jumeaux
Points à noter -
Deux ou plusieurs occurrences de segment d'un type de segment particulier sous un seul segment parent sont appelées segments jumeaux.
Par exemple, 'C1' et 'C2' sont des segments jumeaux, alors faites 'F1' et 'F2' sont.
Segment fraternel
Points à noter -
Les segments frères et sœurs sont les segments de types différents et du même parent.
Par exemple, 'B' et 'E' sont des segments frères. De même,'C1', 'C2', et 'D' sont des segments frères.
Enregistrement de base de données
Points à noter -
Chaque occurrence du segment racine, ainsi que toutes les occurrences de segment subordonné, forment un enregistrement de base de données.
Chaque enregistrement de base de données n'a qu'un seul segment racine, mais il peut avoir n'importe quel nombre d'occurrences de segment.
Dans le traitement de fichier standard, un enregistrement est une unité de données qu'un programme d'application utilise pour certaines opérations. En DL / I, cette unité de données est appelée segment. Un seul enregistrement de base de données a de nombreuses occurrences de segment.
Chemin de la base de données
Points à noter -
Un chemin est la série de segments qui part du segment racine d'un enregistrement de base de données jusqu'à une occurrence de segment spécifique.
Un chemin dans la structure hiérarchique n'a pas besoin d'être complet jusqu'au niveau le plus bas. Cela dépend de la quantité d'informations dont nous avons besoin sur une entité.
Un chemin doit être continu et nous ne pouvons pas sauter des niveaux intermédiaires dans la structure.
Dans la figure suivante, les enregistrements enfants de couleur gris foncé montrent un chemin qui commence à partir de 'A' et passe par 'C2'.
IMS DB stocke les données à différents niveaux. Les données sont récupérées et insérées en émettant des appels DL / I à partir d'un programme d'application. Nous discuterons en détail des appels DL / I dans les prochains chapitres. Les données peuvent être traitées des deux manières suivantes -
- Traitement séquentiel
- Traitement aléatoire
Traitement séquentiel
Lorsque les segments sont extraits séquentiellement de la base de données, DL / I suit un modèle prédéfini. Comprenons le traitement séquentiel d'IMS DB.
Vous trouverez ci-dessous les points à noter concernant le traitement séquentiel -
Le modèle prédéfini pour accéder aux données dans DL / I est d'abord dans la hiérarchie, puis de gauche à droite.
Le segment racine est récupéré en premier, puis DL / I se déplace vers le premier enfant à gauche et il descend jusqu'au niveau le plus bas. Au niveau le plus bas, il récupère toutes les occurrences des segments jumeaux. Ensuite, il va au bon segment.
Pour mieux comprendre, observez les flèches dans la figure ci-dessus qui montrent le flux d'accès aux segments. La bibliothèque est le segment racine et le flux commence à partir de là et va jusqu'aux voitures pour accéder à un seul enregistrement. Le même processus est répété pour toutes les occurrences pour obtenir tous les enregistrements de données.
Lors de l'accès aux données, le programme utilise le position dans la base de données qui permet de récupérer et d'insérer des segments.
Traitement aléatoire
Le traitement aléatoire est également appelé traitement direct des données dans IMS DB. Prenons un exemple pour comprendre le traitement aléatoire dans IMS DB -
Vous trouverez ci-dessous les points à noter sur le traitement aléatoire -
L'occurrence de segment qui doit être récupérée de manière aléatoire nécessite des champs clés de tous les segments dont elle dépend. Ces champs clés sont fournis par le programme d'application.
Une clé concaténée identifie complètement le chemin du segment racine vers le segment que vous souhaitez récupérer.
Supposons que vous souhaitiez récupérer une occurrence du segment Commerce, alors vous devez fournir les valeurs de champ clé concaténées des segments dont il dépend, tels que Bibliothèque, Livres et Commerce.
Le traitement aléatoire est plus rapide que le traitement séquentiel. Dans un scénario réel, les applications combinent des méthodes de traitement séquentielles et aléatoires pour obtenir les meilleurs résultats.
Champ clé
Points à noter -
Un champ clé est également appelé champ de séquence.
Un champ clé est présent dans un segment et il est utilisé pour récupérer l'occurrence du segment.
Un champ clé gère l'occurrence du segment dans l'ordre croissant.
Dans chaque segment, un seul champ peut être utilisé comme champ clé ou champ de séquence.
Champ de recherche
Comme mentionné, un seul champ peut être utilisé comme champ clé. Si vous souhaitez rechercher le contenu d'autres champs de segment qui ne sont pas des champs clés, le champ utilisé pour récupérer les données est appelé champ de recherche.
Les blocs de contrôle IMS définissent la structure de la base de données IMS et l'accès d'un programme à celles-ci. Le diagramme suivant montre la structure des blocs de contrôle IMS.
DL / I utilise les trois types de blocs de contrôle suivants -
- Descripteur de base de données (DBD)
- Bloc de spécification de programme (PSB)
- Bloc de contrôle d'accès (ACB)
Descripteur de base de données (DBD)
Points à noter -
DBD décrit la structure physique complète de la base de données une fois que tous les segments ont été définis.
Lors de l'installation d'une base de données DL / I, un DBD doit être créé car il est nécessaire pour accéder à la base de données IMS.
Les applications peuvent utiliser différentes vues du DBD. Elles sont appelées structures de données d'application et sont spécifiées dans le bloc de spécification de programme.
L'administrateur de base de données crée un DBD en codant DBDGEN instructions de contrôle.
DBDGEN
DBDGEN est un générateur de descripteur de base de données. La création de blocs de contrôle relève de la responsabilité de l'administrateur de la base de données. Tous les modules de chargement sont stockés dans la bibliothèque IMS. Les instructions de macro du langage d'assemblage sont utilisées pour créer des blocs de contrôle. Vous trouverez ci-dessous un exemple de code qui montre comment créer un DBD à l'aide des instructions de contrôle DBDGEN -
PRINT NOGEN
DBD NAME=LIBRARY,ACCESS=HIDAM
DATASET DD1=LIB,DEVICE=3380
SEGM NAME=LIBSEG,PARENT=0,BYTES=10
FIELD NAME=(LIBRARY,SEQ,U),BYTES=10,START=1,TYPE=C
SEGM NAME=BOOKSEG,PARENT=LIBSEG,BYTES=5
FIELD NAME=(BOOKS,SEQ,U),BYTES=10,START=1,TYPE=C
SEGM NAME=MAGSEG,PARENT=LIBSEG,BYTES=9
FIELD NAME=(MAGZINES,SEQ),BYTES=8,START=1,TYPE=C
DBDGEN
FINISH
END
Comprenons les termes utilisés dans le DBDGEN ci-dessus -
Lorsque vous exécutez les instructions de contrôle ci-dessus dans JCL, il crée une structure physique où LIBRARY est le segment racine et BOOKS et MAGZINES sont ses segments enfants.
La première instruction de macro DBD identifie la base de données. Ici, nous devons mentionner le NOM et l'ACCÈS qui sont utilisés par DL / I pour accéder à cette base de données.
La deuxième instruction de macro DATASET identifie le fichier qui contient la base de données.
Les types de segment sont définis à l'aide de l'instruction de macro SEGM. Nous devons spécifier le PARENT de ce segment. S'il s'agit d'un segment racine, mentionnez PARENT = 0.
Le tableau suivant montre les paramètres utilisés dans l'instruction de macro FIELD -
S. Non | Paramètre et description |
---|---|
1 | Name Nom du champ, généralement de 1 à 8 caractères |
2 | Bytes Longueur du champ |
3 | Start Position du champ dans le segment |
4 | Type Type de données du champ |
5 | Type C Type de données de caractère |
6 | Type P Type de données décimal compressé |
sept | Type Z Type de données décimales zonées |
8 | Type X Type de données hexadécimal |
9 | Type H Type de données binaire demi-mot |
dix | Type F Type de données binaire mot complet |
Bloc de spécification de programme (PSB)
Les fondamentaux de PSB sont indiqués ci-dessous -
Une base de données a une structure physique unique définie par un DBD, mais les programmes d'application qui la traitent peuvent avoir différentes vues de la base de données. Ces vues sont appelées structure de données d'application et sont définies dans le PSB.
Aucun programme ne peut utiliser plus d'un PSB en une seule exécution.
Les programmes d'application ont leur propre PSB et il est courant pour les programmes d'application qui ont des exigences de traitement de base de données similaires de partager un PSB.
PSB se compose d'un ou plusieurs blocs de contrôle appelés blocs de communication de programme (PCB). Le PSB contient un PCB pour chaque base de données DL / I à laquelle le programme d'application accédera. Nous discuterons plus en détail des PCB dans les prochains modules.
PSBGEN doit être effectué pour créer un PSB pour le programme.
PSBGEN
PSBGEN est connu sous le nom de générateur de blocs de spécification de programme. L'exemple suivant crée un PSB à l'aide de PSBGEN -
PRINT NOGEN
PCB TYPE=DB,DBDNAME=LIBRARY,KEYLEN=10,PROCOPT=LS
SENSEG NAME=LIBSEG
SENSEG NAME=BOOKSEG,PARENT=LIBSEG
SENSEG NAME=MAGSEG,PARENT=LIBSEG
PSBGEN PSBNAME=LIBPSB,LANG=COBOL
END
Comprenons les termes utilisés dans le DBDGEN ci-dessus -
La première instruction de macro est le Program Communication Block (PCB) qui décrit le type de base de données, le nom, la longueur de clé et l'option de traitement.
Le paramètre DBDNAME de la macro PCB spécifie le nom du DBD. KEYLEN spécifie la longueur de la clé concaténée la plus longue. Le programme peut traiter dans la base de données. Le paramètre PROCOPT spécifie les options de traitement du programme. Par exemple, LS signifie uniquement LOAD Operations.
SENSEG est connu sous le nom de sensibilité au niveau du segment. Il définit l'accès du programme à des parties de la base de données et il est identifié au niveau du segment. Le programme a accès à tous les champs des segments auxquels il est sensible. Un programme peut également avoir une sensibilité au niveau du champ. En cela, nous définissons un nom de segment et le nom parent du segment.
La dernière instruction macro est PCBGEN. PSBGEN est la dernière déclaration indiquant qu'il n'y a plus de déclarations à traiter. PSBNAME définit le nom donné au module PSB de sortie. Le paramètre LANG spécifie la langue dans laquelle le programme d'application est écrit, par exemple COBOL.
Bloc de contrôle d'accès (ACB)
Vous trouverez ci-dessous les points à noter concernant les blocs de contrôle d'accès -
Les blocs de contrôle d'accès pour un programme d'application combinent le descripteur de base de données et le bloc de spécification de programme sous une forme exécutable.
ACBGEN est connu sous le nom de générateur de blocs de contrôle d'accès. Il est utilisé pour générer des ACB.
Pour les programmes en ligne, nous devons pré-construire des ACB. L'utilitaire ACBGEN est donc exécuté avant d'exécuter le programme d'application.
Pour les programmes batch, les ACB peuvent également être générés au moment de l'exécution.
Un programme d'application qui comprend des appels DL / I ne peut pas s'exécuter directement. À la place, un JCL est requis pour déclencher le module de traitement par lots IMS DL / I. Le module d'initialisation par lots dans IMS est DFSRRC00. Le programme d'application et le module DL / I s'exécutent ensemble. Le diagramme suivant montre la structure d'un programme d'application qui comprend des appels DL / I pour accéder à une base de données.
Le programme d'application s'interface avec les modules IMS DL / I via les éléments de programme suivants -
Une instruction ENTRY spécifie que les PCB sont utilisés par le programme.
Un masque de PCB est associé aux informations conservées dans le PCB pré-construit qui reçoit les informations de retour de l'IMS.
Une zone d'entrée-sortie est utilisée pour transmettre des segments de données vers et depuis la base de données IMS.
Les appels à DL / I spécifient les fonctions de traitement telles que récupérer, insérer, supprimer, remplacer, etc.
Vérifier les codes d'état est utilisé pour vérifier le code de retour SQL de l'option de traitement spécifiée pour indiquer si l'opération a réussi ou non.
Une instruction Terminate est utilisée pour terminer le traitement du programme d'application qui inclut le DL / I.
Disposition des segments
À partir de maintenant, nous avons appris que l'IMS se compose de segments qui sont utilisés dans des langages de programmation de haut niveau pour accéder aux données. Considérez la structure de base de données IMS suivante d'une bibliothèque que nous avons vue précédemment et nous voyons ici la disposition de ses segments en COBOL -
01 LIBRARY-SEGMENT.
05 BOOK-ID PIC X(5).
05 ISSUE-DATE PIC X(10).
05 RETURN-DATE PIC X(10).
05 STUDENT-ID PIC A(25).
01 BOOK-SEGMENT.
05 BOOK-ID PIC X(5).
05 BOOK-NAME PIC A(30).
05 AUTHOR PIC A(25).
01 STUDENT-SEGMENT.
05 STUDENT-ID PIC X(5).
05 STUDENT-NAME PIC A(25).
05 DIVISION PIC X(10).
Aperçu du programme d'application
La structure d'un programme d'application IMS est différente de celle d'un programme d'application non IMS. Un programme IMS ne peut pas être exécuté directement; il est plutôt toujours appelé comme sous-programme. Un programme d'application IMS se compose de blocs de spécification de programme pour fournir une vue de la base de données IMS.
Le programme d'application et les PSB liés à ce programme sont chargés lorsque nous exécutons un programme d'application qui comprend des modules IMS DL / I. Ensuite, les requêtes CALL déclenchées par les programmes applicatifs sont exécutées par le module IMS.
Services IMS
Les services IMS suivants sont utilisés par le programme d'application -
- Accès aux enregistrements de la base de données
- Émettre des commandes IMS
- Émettre des appels de service IMS
- Appels de point de contrôle
- Synchroniser les appels
- Envoi ou réception de messages à partir de terminaux d'utilisateurs en ligne
Nous incluons les appels DL / I dans le programme d'application COBOL pour communiquer avec la base de données IMS. Nous utilisons les instructions DL / I suivantes dans le programme COBOL pour accéder à la base de données -
- Déclaration d'entrée
- Déclaration de Goback
- Déclaration d'appel
Déclaration d'entrée
Il est utilisé pour passer le contrôle du DL / I au programme COBOL. Voici la syntaxe de l'instruction d'entrée -
ENTRY 'DLITCBL' USING pcb-name1
[pcb-name2]
La déclaration ci-dessus est codée dans le Procedure Divisiond'un programme COBOL. Entrons dans les détails de l'instruction d'entrée dans le programme COBOL -
Le module d'initialisation par lots déclenche le programme d'application et est exécuté sous son contrôle.
Le DL / I charge les blocs de commande et les modules nécessaires ainsi que le programme d'application, et le contrôle est donné au programme d'application.
DLITCBL signifie DL/I to COBOL. L'instruction d'entrée est utilisée pour définir le point d'entrée dans le programme.
Lorsque nous appelons un sous-programme en COBOL, son adresse est également fournie. De même, lorsque le DL / I donne le contrôle au programme d'application, il fournit également l'adresse de chaque PCB défini dans le PSB du programme.
Tous les PCB utilisés dans le programme d'application doivent être définis à l'intérieur du Linkage Section du programme COBOL car PCB réside en dehors du programme d'application.
La définition du PCB à l'intérieur de la section Linkage est appelée PCB Mask.
La relation entre les masques PCB et les PCB réels stockés est créée en listant les PCB dans la déclaration d'entrée. La séquence d'inscription dans la déclaration d'entrée doit être la même que celle figurant dans le PSBGEN.
Déclaration de Goback
Il est utilisé pour renvoyer le contrôle au programme de contrôle IMS. Voici la syntaxe de l'instruction Goback -
GOBACK
Vous trouverez ci-dessous les points fondamentaux à noter concernant la déclaration Goback -
GOBACK est codé à la fin du programme d'application. Il renvoie le contrôle à DL / I à partir du programme.
Nous ne devons pas utiliser STOP RUN car il renvoie le contrôle au système d'exploitation. Si nous utilisons STOP RUN, le DL / I n'a jamais la possibilité d'exécuter ses fonctions de terminaison. C'est pourquoi, dans les programmes d'application DL / I, l'instruction Goback est utilisée.
Avant d'émettre une instruction Goback, tous les ensembles de données non DL / I utilisés dans le programme d'application COBOL doivent être fermés, sinon le programme se terminera anormalement.
Déclaration d'appel
L'instruction Call est utilisée pour demander des services DL / I tels que l'exécution de certaines opérations sur la base de données IMS. Voici la syntaxe de l'instruction call -
CALL 'CBLTDLI' USING DLI Function Code
PCB Mask
Segment I/O Area
[Segment Search Arguments]
La syntaxe ci-dessus montre les paramètres que vous pouvez utiliser avec l'instruction call. Nous discuterons de chacun d'eux dans le tableau suivant -
S.No. | Paramètre et description |
---|---|
1 | DLI Function Code Identifie la fonction DL / I à exécuter. Cet argument est le nom des quatre champs de caractères qui décrivent l'opération d'E / S. |
2 | PCB Mask La définition de PCB à l'intérieur de la section de liaison est appelée masque de PCB. Ils sont utilisés dans l'instruction d'entrée. Aucune instruction SELECT, ASSIGN, OPEN ou CLOSE n'est requise. |
3 | Segment I/O Area Nom d'une zone de travail d'entrée / sortie. Il s'agit d'une zone du programme d'application dans laquelle le DL / I place un segment demandé. |
4 | Segment Search Arguments Ce sont des paramètres optionnels en fonction du type de l'appel émis. Ils sont utilisés pour rechercher des segments de données dans la base de données IMS. |
Vous trouverez ci-dessous les points à noter concernant l'instruction Call -
CBLTDLI signifie COBOL to DL/I. Il s'agit du nom d'un module d'interface édité en lien avec le module objet de votre programme.
Après chaque appel DL / I, le DLI stocke un code d'état dans le PCB. Le programme peut utiliser ce code pour déterminer si l'appel a réussi ou échoué.
Exemple
Pour plus de compréhension de COBOL, vous pouvez consulter notre tutoriel COBOL ici . L'exemple suivant montre la structure d'un programme COBOL qui utilise la base de données IMS et les appels DL / I. Nous discuterons en détail de chacun des paramètres utilisés dans l'exemple dans les prochains chapitres.
IDENTIFICATION DIVISION.
PROGRAM-ID. TEST1.
DATA DIVISION.
WORKING-STORAGE SECTION.
01 DLI-FUNCTIONS.
05 DLI-GU PIC X(4) VALUE 'GU '.
05 DLI-GHU PIC X(4) VALUE 'GHU '.
05 DLI-GN PIC X(4) VALUE 'GN '.
05 DLI-GHN PIC X(4) VALUE 'GHN '.
05 DLI-GNP PIC X(4) VALUE 'GNP '.
05 DLI-GHNP PIC X(4) VALUE 'GHNP'.
05 DLI-ISRT PIC X(4) VALUE 'ISRT'.
05 DLI-DLET PIC X(4) VALUE 'DLET'.
05 DLI-REPL PIC X(4) VALUE 'REPL'.
05 DLI-CHKP PIC X(4) VALUE 'CHKP'.
05 DLI-XRST PIC X(4) VALUE 'XRST'.
05 DLI-PCB PIC X(4) VALUE 'PCB '.
01 SEGMENT-I-O-AREA PIC X(150).
LINKAGE SECTION.
01 STUDENT-PCB-MASK.
05 STD-DBD-NAME PIC X(8).
05 STD-SEGMENT-LEVEL PIC XX.
05 STD-STATUS-CODE PIC XX.
05 STD-PROC-OPTIONS PIC X(4).
05 FILLER PIC S9(5) COMP.
05 STD-SEGMENT-NAME PIC X(8).
05 STD-KEY-LENGTH PIC S9(5) COMP.
05 STD-NUMB-SENS-SEGS PIC S9(5) COMP.
05 STD-KEY PIC X(11).
PROCEDURE DIVISION.
ENTRY 'DLITCBL' USING STUDENT-PCB-MASK.
A000-READ-PARA.
110-GET-INVENTORY-SEGMENT.
CALL ‘CBLTDLI’ USING DLI-GN
STUDENT-PCB-MASK
SEGMENT-I-O-AREA.
GOBACK.
La fonction DL / I est le premier paramètre utilisé dans un appel DL / I. Cette fonction indique quelle opération va être effectuée sur la base de données IMS par l'appel IMS DL / I. La syntaxe de la fonction DL / I est la suivante -
01 DLI-FUNCTIONS.
05 DLI-GU PIC X(4) VALUE 'GU '.
05 DLI-GHU PIC X(4) VALUE 'GHU '.
05 DLI-GN PIC X(4) VALUE 'GN '.
05 DLI-GHN PIC X(4) VALUE 'GHN '.
05 DLI-GNP PIC X(4) VALUE 'GNP '.
05 DLI-GHNP PIC X(4) VALUE 'GHNP'.
05 DLI-ISRT PIC X(4) VALUE 'ISRT'.
05 DLI-DLET PIC X(4) VALUE 'DLET'.
05 DLI-REPL PIC X(4) VALUE 'REPL'.
05 DLI-CHKP PIC X(4) VALUE 'CHKP'.
05 DLI-XRST PIC X(4) VALUE 'XRST'.
05 DLI-PCB PIC X(4) VALUE 'PCB '.
Cette syntaxe représente les points clés suivants -
Pour ce paramètre, nous pouvons fournir n'importe quel nom à quatre caractères comme champ de stockage pour stocker le code de fonction.
Le paramètre de fonction DL / I est codé dans la section de mémoire de travail du programme COBOL.
Pour spécifier la fonction DL / I, le programmeur doit coder l'un des noms de données de niveau 05 tels que DLI-GU dans un appel DL / I, car COBOL ne permet pas de coder des littéraux sur une instruction CALL.
Les fonctions DL / I sont divisées en trois catégories: Obtenir, Mettre à jour et Autres fonctions. Laissez-nous discuter de chacun d'eux en détail.
Obtenir des fonctions
Les fonctions Get sont similaires à l'opération de lecture prise en charge par n'importe quel langage de programmation. La fonction Get est utilisée pour récupérer des segments à partir d'une base de données IMS DL / I. Les fonctions Get suivantes sont utilisées dans IMS DB -
- Soyez unique
- Procéder au suivant
- Passer au suivant dans Parent
- Soyez unique
- Attendez ensuite
- Get Hold Next dans Parent
Considérons la structure de base de données IMS suivante pour comprendre les appels de fonction DL / I -
Soyez unique
Le code 'GU' est utilisé pour la fonction Get Unique. Cela fonctionne de manière similaire à l'instruction de lecture aléatoire dans COBOL. Il est utilisé pour récupérer une occurrence de segment particulière en fonction des valeurs de champ. Les valeurs de champ peuvent être fournies à l'aide d'arguments de recherche de segment. La syntaxe d'un appel GU est la suivante -
CALL 'CBLTDLI' USING DLI-GU
PCB Mask
Segment I/O Area
[Segment Search Arguments]
Si vous exécutez l'instruction d'appel ci-dessus en fournissant les valeurs appropriées pour tous les paramètres dans le programme COBOL, vous pouvez récupérer le segment dans la zone d'E / S de segment à partir de la base de données. Dans l'exemple ci-dessus, si vous fournissez les valeurs de champ Bibliothèque, Magazines et Santé, vous obtenez l'occurrence souhaitée du segment Santé.
Procéder au suivant
Le code 'GN' est utilisé pour la fonction Get Next. Cela fonctionne de manière similaire à l'instruction suivante de lecture en COBOL. Il est utilisé pour récupérer les occurrences de segment dans une séquence. Le modèle prédéfini pour accéder aux occurrences de segment de données se situe dans la hiérarchie, puis de gauche à droite. La syntaxe d'un appel GN est la suivante -
CALL 'CBLTDLI' USING DLI-GN
PCB Mask
Segment I/O Area
[Segment Search Arguments]
Si vous exécutez l'instruction d'appel ci-dessus en fournissant des valeurs appropriées pour tous les paramètres dans le programme COBOL, vous pouvez récupérer l'occurrence de segment dans la zone d'E / S de segment à partir de la base de données dans un ordre séquentiel. Dans l'exemple ci-dessus, cela commence par accéder au segment Bibliothèque, puis au segment Livres, et ainsi de suite. Nous effectuons l'appel GN encore et encore, jusqu'à ce que nous atteignions l'occurrence de segment souhaitée.
Passer au suivant dans Parent
Le code 'GNP' est utilisé pour Get Next dans Parent. Cette fonction est utilisée pour récupérer les occurrences de segment dans une séquence subordonnée à un segment parent établi. La syntaxe d'un appel GNP est la suivante -
CALL 'CBLTDLI' USING DLI-GNP
PCB Mask
Segment I/O Area
[Segment Search Arguments]
Soyez unique
Le code «GHU» est utilisé pour Get Hold Unique. La fonction Hold spécifie que nous allons mettre à jour le segment après la récupération. La fonction Get Hold Unique correspond à l'appel Get Unique. Voici la syntaxe d'un appel GHU -
CALL 'CBLTDLI' USING DLI-GHU
PCB Mask
Segment I/O Area
[Segment Search Arguments]
Attendez ensuite
Le code 'GHN' est utilisé pour Get Hold Next. La fonction Hold spécifie que nous allons mettre à jour le segment après la récupération. La fonction Get Hold Next correspond à l'appel Get Next. Ci-dessous, la syntaxe d'un appel GHN -
CALL 'CBLTDLI' USING DLI-GHN
PCB Mask
Segment I/O Area
[Segment Search Arguments]
Get Hold Next dans Parent
Le code 'GHNP' est utilisé pour Get Hold Next dans Parent. La fonction Hold spécifie que nous allons mettre à jour le segment après la récupération. La fonction Get Hold Next dans Parent correspond à l'appel Get Next dans Parent. Voici la syntaxe d'un appel GHNP -
CALL 'CBLTDLI' USING DLI-GHNP
PCB Mask
Segment I/O Area
[Segment Search Arguments]
Fonctions de mise à jour
Les fonctions de mise à jour sont similaires aux opérations de réécriture ou d'insertion dans tout autre langage de programmation. Les fonctions de mise à jour sont utilisées pour mettre à jour des segments dans une base de données IMS DL / I. Avant d'utiliser la fonction de mise à jour, il doit y avoir un appel réussi avec la clause Hold pour l'occurrence de segment. Les fonctions de mise à jour suivantes sont utilisées dans IMS DB -
- Insert
- Delete
- Replace
Insérer
Le code «ISRT» est utilisé pour la fonction d'insertion. La fonction ISRT est utilisée pour ajouter un nouveau segment à la base de données. Il est utilisé pour modifier une base de données existante ou charger une nouvelle base de données. Vous trouverez ci-dessous la syntaxe d'un appel ISRT -
CALL 'CBLTDLI' USING DLI-ISRT
PCB Mask
Segment I/O Area
[Segment Search Arguments]
Effacer
Le code «DLET» est utilisé pour la fonction Supprimer. Il est utilisé pour supprimer un segment d'une base de données IMS DL / I. Vous trouverez ci-dessous la syntaxe d'un appel DLET -
CALL 'CBLTDLI' USING DLI-DLET
PCB Mask
Segment I/O Area
[Segment Search Arguments]
Remplacer
Le code 'REPL' est utilisé pour Get Hold Next dans Parent. La fonction Remplacer est utilisée pour remplacer un segment dans la base de données IMS DL / I. Voici la syntaxe d'un appel REPL -
CALL 'CBLTDLI' USING DLI-REPL
PCB Mask
Segment I/O Area
[Segment Search Arguments]
Autres fonctions
Les autres fonctions suivantes sont utilisées dans les appels IMS DL / I -
- Checkpoint
- Restart
- PCB
Point de contrôle
Le code 'CHKP' est utilisé pour la fonction Checkpoint. Il est utilisé dans les fonctionnalités de récupération d'IMS. Voici la syntaxe d'un appel CHKP -
CALL 'CBLTDLI' USING DLI-CHKP
PCB Mask
Segment I/O Area
[Segment Search Arguments]
Redémarrer
Le code «XRST» est utilisé pour la fonction de redémarrage. Il est utilisé dans les fonctionnalités de redémarrage d'IMS. Voici la syntaxe d'un appel XRST -
CALL 'CBLTDLI' USING DLI-XRST
PCB Mask
Segment I/O Area
[Segment Search Arguments]
PCB
La fonction PCB est utilisée dans les programmes CICS de la base de données IMS DL / I. Voici la syntaxe d'un appel PCB -
CALL 'CBLTDLI' USING DLI-PCB
PCB Mask
Segment I/O Area
[Segment Search Arguments]
Vous pouvez trouver plus de détails sur ces fonctions dans le chapitre de récupération.
PCB signifie Program Communication Block. PCB Mask est le deuxième paramètre utilisé dans l'appel DL / I. Il est déclaré dans la section de liaison. Ci-dessous, la syntaxe d'un masque PCB -
01 PCB-NAME.
05 DBD-NAME PIC X(8).
05 SEG-LEVEL PIC XX.
05 STATUS-CODE PIC XX.
05 PROC-OPTIONS PIC X(4).
05 RESERVED-DLI PIC S9(5).
05 SEG-NAME PIC X(8).
05 LENGTH-FB-KEY PIC S9(5).
05 NUMB-SENS-SEGS PIC S9(5).
05 KEY-FB-AREA PIC X(n).
Voici les points clés à noter -
Pour chaque base de données, le DL / I gère une zone de stockage appelée bloc de communication du programme. Il stocke les informations sur la base de données accessibles dans les programmes d'application.
L'instruction ENTRY crée une connexion entre les masques PCB dans la section Linkage et les PCB dans le PSB du programme. Les masques PCB utilisés dans un appel DL / I indiquent la base de données à utiliser pour l'opération.
Vous pouvez supposer que cela revient à spécifier un nom de fichier dans une instruction COBOL READ ou un nom d'enregistrement dans une instruction d'écriture COBOL. Aucune instruction SELECT, ASSIGN, OPEN ou CLOSE n'est requise.
Après chaque appel DL / I, le DL / I stocke un code d'état dans le PCB et le programme peut utiliser ce code pour déterminer si l'appel a réussi ou échoué.
Nom du PCB
Points à noter -
PCB Name est le nom de la zone qui fait référence à l'ensemble de la structure des champs PCB.
PCB Name est utilisé dans les instructions de programme.
Le nom du PCB n'est pas un champ dans le PCB.
Nom DBD
Points à noter -
Le nom DBD contient les données de caractère. Il fait huit octets.
Le premier champ dans le PCB est le nom de la base de données en cours de traitement et il fournit le nom DBD de la bibliothèque de descriptions de base de données associée à une base de données particulière.
Niveau du segment
Points à noter -
Le niveau de segment est appelé indicateur de niveau de hiérarchie de segment. Il contient des données de caractère et fait deux octets.
Un champ de niveau de segment stocke le niveau du segment qui a été traité. Lorsqu'un segment est récupéré avec succès, le numéro de niveau du segment récupéré est stocké ici.
Un champ de niveau de segment n'a jamais une valeur supérieure à 15 car il s'agit du nombre maximal de niveaux autorisés dans une base de données DL / I.
Code d'état
Points à noter -
Le champ de code d'état contient deux octets de données de caractère.
Le code d'état contient le code d'état DL / I.
Les espaces sont déplacés vers le champ de code d'état lorsque DL / I termine le traitement des appels avec succès.
Les valeurs sans espace indiquent que l'appel n'a pas abouti.
Le code d'état GB indique la fin du fichier et le code d'état GE indique que le segment demandé est introuvable.
Options de processus
Points à noter -
Les options Proc sont appelées options de traitement qui contiennent des champs de données à quatre caractères.
Un champ Option de traitement indique le type de traitement que le programme est autorisé à effectuer sur la base de données.
Réservé DL / I
Points à noter -
Le DL / I réservé est appelé la zone réservée de l'IMS. Il stocke quatre octets de données binaires.
IMS utilise ce domaine pour son propre lien interne lié à un programme d'application.
Nom du segment
Points à noter -
Le nom SEG est connu sous le nom de zone de retour de nom de segment. Il contient 8 octets de données de caractères.
Le nom du segment est stocké dans ce champ après chaque appel DL / I.
Clé FB de longueur
Points à noter -
La longueur de la touche FB correspond à la longueur de la zone de rétroaction des touches. Il stocke quatre octets de données binaires.
Ce champ est utilisé pour indiquer la longueur de la clé concaténée du segment de niveau le plus bas traité lors de l'appel précédent.
Il est utilisé avec la zone de rétroaction clé.
Nombre de segments de sensibilité
Points à noter -
Le nombre de segments de sensibilité stocke quatre octets de données binaires.
Il définit à quel niveau un programme d'application est sensible. Il représente un nombre de segments dans la structure de données logique.
Zone de rétroaction clé
Points à noter -
La zone de rétroaction clé varie en longueur d'un PCB à l'autre.
Il contient la clé concaténée la plus longue possible qui peut être utilisée avec la vue du programme de la base de données.
Après une opération de base de données, DL / I renvoie la clé concaténée du segment de niveau le plus bas traité dans ce champ et renvoie la longueur de la clé dans la zone de retour de longueur de clé.
SSA signifie Arguments de recherche de segment. SSA est utilisé pour identifier l'occurrence de segment en cours d'accès. C'est un paramètre facultatif. Nous pouvons inclure n'importe quel nombre de SSA en fonction des besoins. Il existe deux types de SSA -
- SSA non qualifié
- Qualifié SSA
SSA non qualifié
Un SSA non qualifié fournit le nom du segment utilisé dans l'appel. Vous trouverez ci-dessous la syntaxe d'un SSA non qualifié -
01 UNQUALIFIED-SSA.
05 SEGMENT-NAME PIC X(8).
05 FILLER PIC X VALUE SPACE.
Les points clés du SSA non qualifié sont les suivants:
Un SSA de base non qualifié a une longueur de 9 octets.
Les 8 premiers octets contiennent le nom du segment utilisé pour le traitement.
Le dernier octet contient toujours un espace.
DL / I utilise le dernier octet pour déterminer le type de SSA.
Pour accéder à un segment particulier, déplacez le nom du segment dans le champ SEGMENT-NAME.
Les images suivantes montrent les structures des SSA non qualifiés et qualifiés -
Qualifié SSA
Un SSA qualifié fournit au type de segment l'occurrence de base de données spécifique d'un segment. Vous trouverez ci-dessous la syntaxe d'un SSA qualifié -
01 QUALIFIED-SSA.
05 SEGMENT-NAME PIC X(8).
05 FILLER PIC X(01) VALUE '('.
05 FIELD-NAME PIC X(8).
05 REL-OPR PIC X(2).
05 SEARCH-VALUE PIC X(n).
05 FILLER PIC X(n+1) VALUE ')'.
Les points clés du SSA qualifié sont les suivants -
Les 8 premiers octets d'un SSA qualifié contiennent le nom du segment utilisé pour le traitement.
Le neuvième octet est une parenthèse gauche '('.
Les 8 octets suivants à partir de la dixième position spécifient le nom du champ que nous voulons rechercher.
Après le nom du champ, aux 18 e et 19 e positions, nous spécifions un code opérateur relationnel à deux caractères.
Ensuite, nous spécifions la valeur du champ et dans le dernier octet, il y a une parenthèse droite ')'.
Le tableau suivant présente les opérateurs relationnels utilisés dans un SSA qualifié.
Opérateur relationnel | symbole | La description |
---|---|---|
EQ | = | Égal |
NE | ~ = ˜ | Inégal |
GT | > | Plus grand que |
GE | > = | Meilleur que ou égal |
LT | << | Moins que |
LE | <= | Inférieur ou égal |
Codes de commande
Les codes de commande sont utilisés pour améliorer la fonctionnalité des appels DL / I. Les codes de commande réduisent le nombre d'appels DL / I, ce qui simplifie les programmes. En outre, cela améliore les performances car le nombre d'appels est réduit. L'image suivante montre comment les codes de commande sont utilisés dans les SSA non qualifiés et qualifiés -
Les points clés des codes de commande sont les suivants -
Pour utiliser des codes de commande, spécifier un astérisque dans le 9 ème position de la SSA comme indiqué dans l'image ci - dessus.
Le code de commande est codé à la dixième position.
À partir de la 10 e position, DL / I considère tous les caractères comme des codes de commande jusqu'à ce qu'il rencontre un espace pour un SSA non qualifié et une parenthèse gauche pour un SSA qualifié.
Le tableau suivant présente la liste des codes de commande utilisés en SSA -
Code de commande | La description |
---|---|
C | Clé concaténée |
ré | Appel de chemin |
F | Première occurrence |
L | Dernière occurrence |
N | Ignorer l'appel de chemin |
P | Définir la filiation |
Q | Segment de mise en file d'attente |
U | Maintenir sa position à ce niveau |
V | Maintenir la position à ce niveau et à tous les niveaux ci-dessus |
- | Code de commande nul |
Qualifications multiples
Les points fondamentaux de plusieurs qualifications sont les suivants:
Plusieurs qualifications sont requises lorsque nous devons utiliser deux ou plusieurs qualifications ou domaines à des fins de comparaison.
Nous utilisons des opérateurs booléens comme AND et OR pour connecter deux ou plusieurs qualifications.
Plusieurs qualifications peuvent être utilisées lorsque nous voulons traiter un segment en fonction d'une plage de valeurs possibles pour un seul champ.
Vous trouverez ci-dessous la syntaxe des qualifications multiples -
01 QUALIFIED-SSA.
05 SEGMENT-NAME PIC X(8).
05 FILLER PIC X(01) VALUE '('.
05 FIELD-NAME1 PIC X(8).
05 REL-OPR PIC X(2).
05 SEARCH-VALUE1 PIC X(m).
05 MUL-QUAL PIC X VALUE '&'.
05 FIELD-NAME2 PIC X(8).
05 REL-OPR PIC X(2).
05 SEARCH-VALUE2 PIC X(n).
05 FILLER PIC X(n+1) VALUE ')'.
MUL-QUAL est un court terme pour MULtiple QUALIification dans lequel nous pouvons fournir des opérateurs booléens comme AND ou OR.
Les différentes méthodes de récupération de données utilisées dans les appels IMS DL / I sont les suivantes:
- Appel GU
- Appel GN
- Utilisation des codes de commande
- Traitement multiple
Considérons la structure de base de données IMS suivante pour comprendre les appels de la fonction de récupération de données -
Appel GU
Les principes fondamentaux de l'appel GU sont les suivants -
L'appel GU est appelé Appel Unique. Il est utilisé pour le traitement aléatoire.
Si une application ne met pas à jour la base de données régulièrement ou si le nombre de mises à jour de la base de données est inférieur, nous utilisons un traitement aléatoire.
L'appel GU est utilisé pour placer le pointeur à une position particulière pour une récupération séquentielle ultérieure.
Les appels GU sont indépendants de la position du pointeur établie par les appels précédents.
Le traitement des appels GU est basé sur les champs de clé uniques fournis dans l'instruction d'appel.
Si nous fournissons un champ clé qui n'est pas unique, DL / I renvoie la première occurrence de segment du champ clé.
CALL 'CBLTDLI' USING DLI-GU
PCB-NAME
IO-AREA
LIBRARY-SSA
BOOKS-SSA
ENGINEERING-SSA
IT-SSA
L'exemple ci-dessus montre que nous émettons un appel GU en fournissant un ensemble complet de SSA qualifiés. Il inclut tous les champs clés à partir du niveau racine jusqu'à l'occurrence de segment que nous voulons récupérer.
Considérations relatives aux appels GU
Si nous ne fournissons pas l'ensemble complet de SSA qualifiés dans l'appel, alors DL / I fonctionne de la manière suivante -
Lorsque nous utilisons une SSA non qualifiée dans un appel GU, DL / I accède à la première occurrence de segment de la base de données qui répond aux critères que vous spécifiez.
Lorsque nous émettons un appel GU sans SSA, DL / I renvoie la première occurrence du segment racine dans la base de données.
Si certains SSA à des niveaux intermédiaires ne sont pas mentionnés dans l'appel, alors DL / I utilise la position établie ou la valeur par défaut d'un SSA non qualifié pour le segment.
Codes d'état
Le tableau suivant montre les codes d'état pertinents après un appel GU -
S. Non | Code d'état et description |
---|---|
1 | Spaces Appel réussi |
2 | GE DL / Je n'ai pas trouvé de segment répondant aux critères spécifiés dans l'appel |
Appel GN
Les principes fondamentaux de l'appel GN sont les suivants -
L'appel GN est appelé Get Next call. Il est utilisé pour le traitement séquentiel de base.
La position initiale du pointeur dans la base de données est avant le segment racine du premier enregistrement de base de données.
La position du pointeur de la base de données est avant l'occurrence de segment suivante dans la séquence, après un appel GN réussi.
L'appel GN commence par la base de données à partir de la position établie par l'appel précédent.
Si un appel GN n'est pas qualifié, il renvoie l'occurrence de segment suivante dans la base de données quel que soit son type, dans une séquence hiérarchique.
Si un appel GN comprend des SSA, DL / I récupère uniquement les segments qui répondent aux exigences de tous les SSA spécifiés.
CALL 'CBLTDLI' USING DLI-GN
PCB-NAME
IO-AREA
BOOKS-SSA
L'exemple ci-dessus montre que nous émettons un appel GN fournissant la position de départ pour lire les enregistrements séquentiellement. Il récupère la première occurrence du segment BOOKS.
Codes d'état
Le tableau suivant montre les codes d'état pertinents après un appel GN -
S. Non | Code d'état et description |
---|---|
1 | Spaces Appel réussi |
2 | GE DL / Je n'ai pas pu trouver un segment répondant aux critères spécifiés dans l'appel. |
3 | GA Un appel GN non qualifié monte d'un niveau dans la hiérarchie de la base de données pour récupérer le segment. |
4 | GB La fin de la base de données est atteinte et le segment est introuvable. |
GK Un appel GN non qualifié tente d'extraire un segment d'un type particulier autre que celui qui vient d'être récupéré mais reste au même niveau hiérarchique. |
Codes de commande
Les codes de commande sont utilisés avec les appels pour récupérer une occurrence de segment. Les différents codes de commande utilisés avec les appels sont décrits ci-dessous.
Code de commande F
Points à noter -
Lorsqu'un code de commande F est spécifié dans un appel, l'appel traite la première occurrence du segment.
Les codes de commande F peuvent être utilisés lorsque nous voulons traiter séquentiellement et il peut être utilisé avec les appels GN et les appels GNP.
Si nous spécifions un code de commande F avec un appel GU, cela n'a aucune signification, car les appels GU récupèrent la première occurrence de segment par défaut.
Code de commande L
Points à noter -
Lorsqu'un code de commande L est spécifié dans un appel, l'appel traite la dernière occurrence du segment.
Les codes de commande L peuvent être utilisés lorsque nous voulons traiter séquentiellement et il peut être utilisé avec les appels GN et les appels GNP.
Code de commande D
Points à noter -
Le code de commande D est utilisé pour récupérer plusieurs occurrences de segment en utilisant un seul appel.
Normalement, DL / I fonctionne sur le segment de niveau le plus bas spécifié dans un SSA, mais dans de nombreux cas, nous voulons également des données d'autres niveaux. Dans ces cas, nous pouvons utiliser le code de commande D.
Le code de commande D facilite la récupération du chemin complet des segments.
Code de commande C
Points à noter -
Le code de commande C est utilisé pour concaténer les clés.
L'utilisation d'opérateurs relationnels est un peu complexe, car nous devons spécifier un nom de champ, un opérateur relationnel et une valeur de recherche. Au lieu de cela, nous pouvons utiliser un code de commande C pour fournir une clé concaténée.
L'exemple suivant montre l'utilisation du code de commande C -
01 LOCATION-SSA.
05 FILLER PIC X(11) VALUE ‘INLOCSEG*C(‘.
05 LIBRARY-SSA PIC X(5).
05 BOOKS-SSA PIC X(4).
05 ENGINEERING-SSA PIC X(6).
05 IT-SSA PIC X(3)
05 FILLER PIC X VALUE ‘)’.
CALL 'CBLTDLI' USING DLI-GU
PCB-NAME
IO-AREA
LOCATION-SSA
Code de commande P
Points à noter -
Lorsque nous émettons un appel GU ou GN, le DL / I établit sa parenté au segment de niveau le plus bas qui est récupéré.
Si nous incluons un code de commande P, alors le DL / I établit sa parenté à un segment de niveau supérieur dans le chemin hiérarchique.
Code de commande U
Points à noter -
Lorsqu'un code de commande U est spécifié dans un SSA non qualifié dans un appel GN, le DL / I restreint la recherche du segment.
Le code de commande U est ignoré s'il est utilisé avec un SSA qualifié.
Code de commande V
Points à noter -
Le code de commande V fonctionne de manière similaire au code de commande U, mais il limite la recherche d'un segment à un niveau particulier et à tous les niveaux au-dessus de la hiérarchie.
Le code de commande V est ignoré lorsqu'il est utilisé avec un SSA qualifié.
Code de commande Q
Points à noter -
Le code de commande Q est utilisé pour mettre en file d'attente ou réserver un segment pour une utilisation exclusive de votre programme d'application.
Le code de commande Q est utilisé dans un environnement interactif où un autre programme peut apporter une modification à un segment.
Traitement multiple
Un programme peut avoir plusieurs positions dans la base de données IMS, ce que l'on appelle le traitement multiple. Le traitement multiple peut être effectué de deux manières -
- PCB multiples
- Positionnement multiple
PCB multiples
Plusieurs PCB peuvent être définis pour une seule base de données. S'il existe plusieurs PCB, un programme d'application peut en avoir différentes vues. Cette méthode de mise en œuvre de traitements multiples est inefficace en raison des frais généraux imposés par les PCB supplémentaires.
Positionnement multiple
Un programme peut maintenir plusieurs positions dans une base de données en utilisant un seul PCB. Ceci est réalisé en maintenant une position distincte pour chaque chemin hiérarchique. Le positionnement multiple est utilisé pour accéder à des segments de deux types ou plus de manière séquentielle en même temps.
Les différentes méthodes de manipulation des données utilisées dans les appels IMS DL / I sont les suivantes:
- Appel ISRT
- Obtenir des appels en attente
- Appel REPL
- Appel DLET
Considérons la structure de base de données IMS suivante pour comprendre les appels de la fonction de manipulation de données -
Appel ISRT
Points à noter -
L'appel ISRT est appelé appel d'insertion qui est utilisé pour ajouter des occurrences de segment à une base de données.
Les appels ISRT sont utilisés pour charger une nouvelle base de données.
Nous émettons un appel ISRT lorsqu'un champ de description de segment est chargé avec des données.
Un SSA non qualifié ou qualifié doit être spécifié dans l'appel afin que le DL / I sache où placer une occurrence de segment.
Nous pouvons utiliser une combinaison de SSA non qualifié et qualifié dans l'appel. Un SSA qualifié peut être spécifié pour tous les niveaux ci-dessus. Prenons l'exemple suivant -
CALL 'CBLTDLI' USING DLI-ISRT
PCB-NAME
IO-AREA
LIBRARY-SSA
BOOKS-SSA
UNQUALIFIED-ENGINEERING-SSA
L'exemple ci-dessus montre que nous émettons un appel ISRT en fournissant une combinaison de SSA qualifiés et non qualifiés.
Lorsqu'un nouveau segment que nous insérons a un champ clé unique, il est ajouté à la bonne position. Si le champ clé n'est pas unique, il est ajouté par les règles définies par un administrateur de base de données.
Lorsque nous émettons un appel ISRT sans spécifier de champ clé, la règle d'insertion indique où placer les segments par rapport aux segments jumeaux existants. Ci-dessous sont les règles d'insertion -
First - Si la règle est la première, le nouveau segment est ajouté avant les jumeaux existants.
Last - Si la règle est la dernière, le nouveau segment est ajouté après tous les jumeaux existants.
Here - Si la règle est ici, elle est ajoutée à la position actuelle par rapport aux jumeaux existants, qui peuvent être le premier, le dernier ou n'importe où.
Codes d'état
Le tableau suivant montre les codes d'état pertinents après un appel ISRT -
S. Non | Code d'état et description |
---|---|
1 | Spaces Appel réussi |
2 | GE Plusieurs SSA sont utilisés et le DL / I ne peut pas satisfaire l'appel avec le chemin spécifié. |
3 | II Essayez d'ajouter une occurrence de segment déjà présente dans la base de données. |
4 | LB / LC LD / LE Nous obtenons ces codes d'état lors du traitement du chargement. Dans la plupart des cas, ils indiquent que vous n'insérez pas les segments dans une séquence hiérarchique exacte. |
Obtenir un appel en attente
Points à noter -
Il existe trois types d'appels Get Hold que nous spécifions dans un appel DL / I:
Get Hold Unique (GHU)
Get Hold Next (GHN)
Get Hold Next dans Parent (GHNP)
La fonction Hold spécifie que nous allons mettre à jour le segment après la récupération. Ainsi, avant un appel REPL ou DLET, un appel en attente réussi doit être émis indiquant au DL / I l'intention de mettre à jour la base de données.
Appel REPL
Points à noter -
Après un appel de mise en attente réussi, nous émettons un appel REPL pour mettre à jour une occurrence de segment.
Nous ne pouvons pas modifier la longueur d'un segment à l'aide d'un appel REPL.
Nous ne pouvons pas modifier la valeur d'un champ clé à l'aide d'un appel REPL.
Nous ne pouvons pas utiliser un SSA qualifié avec un appel REPL. Si nous spécifions un SSA qualifié, l'appel échoue.
CALL 'CBLTDLI' USING DLI-GHU
PCB-NAME
IO-AREA
LIBRARY-SSA
BOOKS-SSA
ENGINEERING-SSA
IT-SSA.
*Move the values which you want to update in IT segment occurrence*
CALL ‘CBLTDLI’ USING DLI-REPL
PCB-NAME
IO-AREA.
L'exemple ci-dessus met à jour l'occurrence du segment informatique à l'aide d'un appel REPL. Tout d'abord, nous émettons un appel GHU pour obtenir l'occurrence de segment que nous voulons mettre à jour. Ensuite, nous émettons un appel REPL pour mettre à jour les valeurs de ce segment.
Appel DLET
Points à noter -
L'appel DLET fonctionne de la même manière qu'un appel REPL.
Après un appel de mise en attente réussi, nous émettons un appel DLET pour supprimer une occurrence de segment.
Nous ne pouvons pas utiliser un SSA qualifié avec un appel DLET. Si nous spécifions un SSA qualifié, l'appel échoue.
CALL 'CBLTDLI' USING DLI-GHU
PCB-NAME
IO-AREA
LIBRARY-SSA
BOOKS-SSA
ENGINEERING-SSA
IT-SSA.
CALL ‘CBLTDLI’ USING DLI-DLET
PCB-NAME
IO-AREA.
L'exemple ci-dessus supprime l'occurrence de segment informatique à l'aide d'un appel DLET. Tout d'abord, nous émettons un appel GHU pour obtenir l'occurrence de segment que nous voulons supprimer. Ensuite, nous émettons un appel DLET pour mettre à jour les valeurs de ce segment.
Codes d'état
Le tableau suivant montre les codes d'état pertinents après un appel REPL ou DLET -
S. Non | Code d'état et description |
---|---|
1 | Spaces Appel réussi |
2 | AJ SSA qualifié utilisé lors d'un appel REPL ou DLET. |
3 | DJ Le programme émet un appel de remplacement sans un appel de mise en attente immédiatement précédent. |
4 | DA Le programme modifie le champ clé du segment avant d'émettre l'appel REPL ou DLET |
L'indexation secondaire est utilisée lorsque nous voulons accéder à une base de données sans utiliser la clé concaténée complète ou lorsque nous ne voulons pas utiliser les champs primaires de séquence.
Segment de pointeur d'index
DL / I stocke le pointeur vers des segments de la base de données indexée dans une base de données distincte. Le segment de pointeur d'index est le seul type d'index secondaire. Il se compose de deux parties -
- Élément de préfixe
- Élément de données
Élément de préfixe
La partie préfixe du segment de pointeur d'index contient un pointeur vers le segment cible d'index. Le segment cible de l'index est le segment accessible à l'aide de l'index secondaire.
Élément de données
L'élément de données contient la valeur de clé du segment de la base de données indexée sur laquelle l'index est construit. Ceci est également connu sous le nom de segment source d'index.
Voici les points clés à noter sur l'indexation secondaire -
Le segment source d'index et le segment source cible ne doivent pas nécessairement être identiques.
Lorsque nous mettons en place un index secondaire, il est automatiquement mis à jour par le DL / I.
Le DBA définit de nombreux index secondaires selon les chemins d'accès multiples. Ces index secondaires sont stockés dans une base de données d'index distincte.
Nous ne devons pas créer plus d'index secondaires, car ils imposent une surcharge de traitement supplémentaire sur le DL / I.
Clés secondaires
Points à noter -
Le champ du segment source d'index sur lequel l'index secondaire est construit est appelé comme clé secondaire.
Tout champ peut être utilisé comme clé secondaire. Il n'est pas nécessaire que ce soit le champ de séquence de segments.
Les clés secondaires peuvent être n'importe quelle combinaison de champs uniques dans le segment source de l'index.
Les valeurs de clé secondaire ne doivent pas être uniques.
Structures de données secondaires
Points à noter -
Lorsque nous construisons un index secondaire, la structure hiérarchique apparente de la base de données est également modifiée.
Le segment cible d'index devient le segment racine apparent. Comme le montre l'image suivante, le segment d'ingénierie devient le segment racine, même s'il ne s'agit pas d'un segment racine.
Le réarrangement de la structure de la base de données provoqué par l'index secondaire est appelé structure de données secondaire.
Les structures de données secondaires n'apportent aucune modification à la structure de base de données physique principale présente sur le disque. Il s'agit simplement d'un moyen de modifier la structure de la base de données devant le programme d'application.
Opérateur AND indépendant
Points à noter -
Lorsqu'un opérateur AND (* ou &) est utilisé avec des index secondaires, il est appelé opérateur AND dépendant.
Un ET indépendant (#) nous permet de spécifier des qualifications qui seraient impossibles avec un ET dépendant.
Cet opérateur ne peut être utilisé que pour les index secondaires où le segment source d'index dépend du segment cible d'index.
Nous pouvons coder un SSA avec un ET indépendant pour spécifier qu'une occurrence du segment cible soit traitée en fonction des champs de deux segments source dépendants ou plus.
01 ITEM-SELECTION-SSA.
05 FILLER PIC X(8).
05 FILLER PIC X(1) VALUE '('.
05 FILLER PIC X(10).
05 SSA-KEY-1 PIC X(8).
05 FILLER PIC X VALUE '#'.
05 FILLER PIC X(10).
05 SSA-KEY-2 PIC X(8).
05 FILLER PIC X VALUE ')'.
Séquençage clairsemé
Points à noter -
Le séquençage clairsemé est également connu sous le nom d'indexation clairsemée. Nous pouvons supprimer certains des segments de source d'index de l'index en utilisant un séquençage fragmenté avec une base de données d'index secondaire.
Un séquençage clairsemé est utilisé pour améliorer les performances. Lorsque certaines occurrences du segment source d'index ne sont pas utilisées, nous pouvons les supprimer.
DL / I utilise une valeur de suppression ou une routine de suppression ou les deux pour déterminer si un segment doit être indexé.
Si la valeur d'un champ de séquence dans le segment source d'index correspond à une valeur de suppression, aucune relation d'index n'est établie.
La routine de suppression est un programme écrit par l'utilisateur qui évalue le segment et détermine s'il doit ou non être indexé.
Lorsqu'une indexation fragmentée est utilisée, ses fonctions sont gérées par le DL / I. Nous n'avons pas besoin de prévoir des dispositions spéciales pour cela dans le programme d'application.
Exigences DBDGEN
Comme indiqué dans les modules précédents, DBDGEN est utilisé pour créer un DBD. Lorsque nous créons des index secondaires, deux bases de données sont impliquées. Un DBA doit créer deux DBD à l'aide de deux DBDGEN pour créer une relation entre une base de données indexée et une base de données indexée secondaire.
Exigences PSBGEN
Après avoir créé l'index secondaire pour une base de données, le DBA doit créer les PSB. PSBGEN pour le programme spécifie la séquence de traitement appropriée pour la base de données sur le paramètre PROCSEQ de la macro PSB. Pour le paramètre PROCSEQ, le DBA code le nom DBD pour la base de données d'index secondaire.
La base de données IMS a une règle selon laquelle chaque type de segment ne peut avoir qu'un seul parent. Cela limite la complexité de la base de données physique. De nombreuses applications DL / I nécessitent une structure complexe qui permet à un segment d'avoir deux types de segments parents. Pour surmonter cette limitation, DL / I permet au DBA d'implémenter des relations logiques dans lesquelles un segment peut avoir des parents physiques et logiques. Nous pouvons créer des relations supplémentaires dans une base de données physique. La nouvelle structure de données après implémentation de la relation logique est connue sous le nom de base de données logique.
Relation logique
Une relation logique a les propriétés suivantes -
Une relation logique est un chemin entre deux segments qui sont liés logiquement et non physiquement.
En général, une relation logique est établie entre des bases de données distinctes. Mais il est possible d'avoir une relation entre les segments d'une base de données particulière.
L'image suivante montre deux bases de données différentes. L'une est une base de données d'étudiants et l'autre est une base de données de bibliothèque. Nous créons une relation logique entre le segment Livres émis de la base de données des étudiants et le segment Livres de la base de données Bibliothèque.
Voici à quoi ressemble la base de données logique lorsque vous créez une relation logique -
Segment enfant logique
Le segment enfant logique est la base d'une relation logique. Il s'agit d'un segment de données physique mais pour DL / I, il semble qu'il ait deux parents. Le segment Livres de l'exemple ci-dessus a deux segments parents. Le segment Livres émis est le parent logique et le segment Bibliothèque est le parent physique. Une occurrence de segment enfant logique n'a qu'une seule occurrence de segment parent logique et une occurrence de segment parent logique peut avoir plusieurs occurrences de segment enfant logique.
Jumeaux logiques
Les jumeaux logiques sont les occurrences d'un type de segment enfant logique qui sont toutes subordonnées à une seule occurrence du type de segment parent logique. DL / I rend le segment enfant logique similaire à un segment enfant physique réel. Ceci est également connu sous le nom de segment enfant logique virtuel.
Types de relations logiques
Un DBA crée des relations logiques entre les segments. Pour implémenter une relation logique, l'administrateur de base de données doit la spécifier dans les DBDGEN des bases de données physiques concernées. Il existe trois types de relations logiques -
- Unidirectional
- Virtuel bidirectionnel
- Physique bidirectionnel
Unidirectionnel
La connexion logique va de l'enfant logique au parent logique et ne peut pas aller dans l'autre sens.
Virtuel bidirectionnel
Il permet l'accès dans les deux sens. L'enfant logique dans sa structure physique et l'enfant logique virtuel correspondant peuvent être considérés comme des segments appariés.
Physique bidirectionnel
L'enfant logique est un subordonné physiquement stocké de ses parents physiques et logiques. Pour les programmes d'application, il apparaît de la même manière qu'un enfant logique virtuel bidirectionnel.
Considérations de programmation
Les considérations de programmation pour l'utilisation d'une base de données logique sont les suivantes:
Les appels DL / I pour accéder à la base de données restent les mêmes avec la base de données logique.
Le bloc de spécification du programme indique la structure que nous utilisons dans nos appels. Dans certains cas, nous ne pouvons pas identifier que nous utilisons une base de données logique.
Les relations logiques ajoutent une nouvelle dimension à la programmation des bases de données.
Vous devez être prudent lorsque vous travaillez avec des bases de données logiques, car deux bases de données sont intégrées ensemble. Si vous modifiez une base de données, les mêmes modifications doivent être reflétées dans l'autre base de données.
Les spécifications du programme doivent indiquer quel traitement est autorisé sur une base de données. Si une règle de traitement n'est pas respectée, vous obtenez un code d'état non vide.
Segment concaténé
Un segment enfant logique commence toujours par la clé concaténée complète du parent de destination. Ceci est connu sous le nom de clé concaténée parente de destination (DPCK). Vous devez toujours coder le DPCK au début de votre zone d'E / S de segment pour un enfant logique. Dans une base de données logique, le segment concaténé établit la connexion entre des segments définis dans différentes bases de données physiques. Un segment concaténé se compose des deux parties suivantes -
- Segment enfant logique
- Segment parent de destination
Un segment enfant logique se compose des deux parties suivantes -
- Clé concaténée parente de destination (DPCK)
- Données logiques de l'utilisateur enfant
Lorsque nous travaillons avec des segments concaténés pendant la mise à jour, il peut être possible d'ajouter ou de modifier les données à la fois dans l'enfant logique et dans le parent de destination avec un seul appel. Cela dépend également des règles spécifiées par le DBA pour la base de données. Pour un insert, placez le DPCK dans la bonne position. Pour un remplacement ou une suppression, ne modifiez pas le DPCK ou les données du champ de séquence dans l'une ou l'autre partie du segment concaténé.
L'administrateur de la base de données doit planifier la récupération de la base de données en cas de défaillance du système. Les pannes peuvent être de plusieurs types, telles que des pannes d'application, des erreurs matérielles, des pannes de courant, etc.
Approche simple
Voici quelques approches simples de la récupération de base de données:
Faites des copies de sauvegarde périodiques des ensembles de données importants afin que toutes les transactions publiées par rapport aux ensembles de données soient conservées.
Si un ensemble de données est endommagé en raison d'une défaillance du système, ce problème est corrigé en restaurant la copie de sauvegarde. Ensuite, les transactions accumulées sont republiées sur la copie de sauvegarde pour les mettre à jour.
Inconvénients de l'approche simple
Les inconvénients d'une approche simple de la récupération de base de données sont les suivants:
Re-comptabiliser les transactions accumulées prend beaucoup de temps.
Toutes les autres applications doivent attendre l'exécution jusqu'à ce que la récupération soit terminée.
La récupération de base de données est plus longue que la récupération de fichier, si des relations d'index logique et secondaire sont impliquées.
Routines de terminaison anormales
Un programme DL / I se bloque d'une manière différente de la manière dont un programme standard se bloque car un programme standard est exécuté directement par le système d'exploitation, alors qu'un programme DL / I ne l'est pas. En employant une routine de terminaison anormale, le système interfère de sorte que la récupération peut être effectuée après la FIN anormale (ABEND). La routine de terminaison anormale effectue les actions suivantes -
- Ferme tous les ensembles de données
- Annule tous les travaux en attente dans la file d'attente
- Crée un vidage de stockage pour découvrir la cause première de ABEND
La limitation de cette routine est qu'elle ne garantit pas si les données utilisées sont exactes ou non.
Journal DL / I
Lorsqu'un programme d'application ABEND, il est nécessaire d'annuler les modifications effectuées par le programme d'application, de corriger l'erreur et de réexécuter le programme d'application. Pour ce faire, il est nécessaire d'avoir le journal DL / I. Voici les points clés sur la journalisation DL / I -
Un DL / I enregistre toutes les modifications apportées par un programme d'application dans un fichier appelé fichier journal.
Lorsque le programme d'application change un segment, ses images avant et après sont créées par le DL / I.
Ces images de segment peuvent être utilisées pour restaurer les segments, en cas de panne du programme d'application.
DL / I utilise une technique appelée journalisation à écriture anticipée pour enregistrer les modifications de la base de données. Avec la journalisation à écriture anticipée, une modification de base de données est écrite dans l'ensemble de données du journal avant d'être écrite dans l'ensemble de données réel.
Comme le journal est toujours en avance sur la base de données, les utilitaires de récupération peuvent déterminer l'état de toute modification de la base de données.
Lorsque le programme exécute un appel pour modifier un segment de base de données, le DL / I s'occupe de sa partie journalisation.
Récupération - avant et arrière
Les deux approches de récupération de base de données sont:
Forward Recovery - DL / I utilise le fichier journal pour stocker les données de modification. Les transactions accumulées sont republiées à l'aide de ce fichier journal.
Backward Recovery- La récupération arrière est également connue sous le nom de récupération arrière. Les enregistrements du journal du programme sont lus à l'envers et leurs effets sont inversés dans la base de données. Lorsque la sauvegarde est terminée, les bases de données sont dans le même état qu'avant l'échec, en supposant qu'aucun autre programme d'application n'a modifié la base de données entre-temps.
Point de contrôle
Un point de contrôle est une étape où les modifications de la base de données effectuées par le programme d'application sont considérées comme complètes et exactes. Voici les points à noter sur un point de contrôle -
Les modifications apportées à la base de données avant le point de contrôle le plus récent ne sont pas annulées par la récupération arrière.
Les modifications de la base de données consignées après le point de contrôle le plus récent ne sont pas appliquées à une copie d'image de la base de données pendant la récupération aval.
À l'aide de la méthode du point de contrôle, la base de données est restaurée à son état au point de contrôle le plus récent lorsque le processus de récupération est terminé.
La valeur par défaut pour les programmes batch est que le point de contrôle est le début du programme.
Un point de contrôle peut être établi à l'aide d'un appel de point de contrôle (CHKP).
Un appel de point de contrôle entraîne l'écriture d'un enregistrement de point de contrôle dans le journal DL / I.
Ci-dessous, la syntaxe d'un appel CHKP -
CALL 'CBLTDLI' USING DLI-CHKP
PCB-NAME
CHECKPOINT-ID
Il existe deux méthodes de point de contrôle -
Basic Checkpointing - Il permet au programmeur d'émettre des appels de point de contrôle que les utilitaires de récupération DL / I utilisent pendant le traitement de récupération.
Symbolic Checkpointing- Il s'agit d'une forme avancée de point de contrôle qui est utilisée en combinaison avec la fonction de redémarrage étendu. Le point de contrôle symbolique et le redémarrage étendu permettent au programmeur d'application de coder les programmes afin qu'ils puissent reprendre le traitement au point juste après le point de contrôle.