Une variable logique MoreRows (c’est-à-dire type indicateur en ILE RPG) contrôle la boucle Fetch (pas montrée dans ce fragment de code). MoreRows devrait être initialisé à True (« 1 ») avant la boucle. Vous ne devez pas utiliser SqlState elle-même pour contrôler une boucle Fetch, parce que SqlState peut être
Vérifier le SQL state (suite)
redéfinie par d’autres instructions SQL qui pourraient se trouver dans le domaine de la boucle ou de vos routines de traitement d’erreurs. (Voir l’encadré « Copier SqlState pour éviter des problèmes » pour plus de détails à ce sujet.) Là encore, vous pouvez faire varier ce profil en appelant des procédures plutôt que des sous-routines ou en ajoutant d’autres tests pour des classes ou états spécifiques supplémentaires.
Pour des instructions SQL comme Insert, où vous voulez détecter des erreurs spécifiques ou simplement aller jusqu’à la bonne fin, utilisez le test de la figure 5. A noter que la ligne « Skip » est simplement un commentaire, et quand Insert réussit, l’exécution passe simplement à l’instruction RPG suivante après Select.
Le deuxième test intercepte une tentative d’insérer une valeur dupliquée pour des colonnes qui ont une clé primaire ou une contrainte unique ou un index unique. En interceptant cette condition spécifique, l’application peut renseigner utilement un utilisateur interactif, lui permettant de récupérer et de conclure la transaction.
Le troisième test intercepte toutes les autres transgressions de contraintes et, là encore, peut permettre à l’application de fournir d’autres informations utiles, même sans permettre la récupération. A noter que le test pour l’état de clé dupliquée (« 23505 ») doit précéder le test pour la classe (« 23 ») qui inclut l’état spécifique. Si l’ordre était inversé, l’état « 23505 » serait intercepté par le test pour la classe « 23 » et serait donc toujours traité comme une erreur de contrainte générale. Il est essentiel dans ce profil, ainsi d’ailleurs qu’avec les autres profils qui mêlent les tests pour des valeurs de classe de deux caractères et des valeurs d’état de cinq caractères, de tester les valeurs d’état de cinq caractères avant de tester pour une classe qui inclut l’une quelconque des valeurs d’état spécifiques.
Toujours par la même méthode, vous pouvez ajouter d’autres conditions When pour traiter d’autres états et/ou classes SQL spécifiques. Vous pouvez baser les profils pour les instructions Delete et Update sur le profil Insert et inclure des tests pour les instructions SQL appropriées, comme ligne non trouvée (« 02000 ») ou ligne verrouillée (« 57033 »).
Dernier conseil : ne songez jamais à l’instruction SQL Whenever pour le traitement d’erreurs. Ce ne peut être qu’une source d’ennuis, comme je l’explique dans l’encadré « Ne jamais, jamais, utiliser Whenever ».
Téléchargez cette ressource
Sécuriser Microsoft 365 avec une approche Zero-Trust
Découvrez comment renforcer la cyber-résilience de Microsoft 365 grâce à une approche Zero-Trust, une administration granulaire et une automatisation avancée. La technologie Virtual Tenant de CoreView permet de sécuriser et simplifier la gestion des environnements complexes, tout en complétant vos stratégies IAM, y compris dans les secteurs réglementés.
Les articles les plus consultés
- Cybersécurité Active Directory et les attaques de nouvelle génération
- N° 2 : Il faut supporter des langues multiples dans SharePoint Portal Server
- Partager vos images, vidéos, musique et imprimante avec le Groupe résidentiel
- IBM i célèbre ses 25 ans
- Afficher les icônes cachées dans la barre de notification
Les plus consultés sur iTPro.fr
- Fuites de données : la France, 2ème pays le plus touché au monde début 2026
- Nomios accélère sur la cybersécurité industrielle avec un SOC renforcé et une Factory OT immersive
- Femmes et métiers de la tech : une attractivité réelle freinée par des stéréotypes persistants
- Reprendre le contrôle de son SI : la clé d’un numérique à la fois souverain et responsable
Articles les + lus
Femmes et métiers de la tech : une attractivité réelle freinée par des stéréotypes persistants
Moderniser le développement logiciel : de la fragmentation à l’intégration
Analyse Patch Tuesday Mars 2026
Une nouvelle ère de la modernisation du mainframe
Communes, entreprises ? Non, face au RGAA 5, l’IA seule ne rendra pas vos sites accessibles
À la une de la chaîne Tech
- Femmes et métiers de la tech : une attractivité réelle freinée par des stéréotypes persistants
- Moderniser le développement logiciel : de la fragmentation à l’intégration
- Analyse Patch Tuesday Mars 2026
- Une nouvelle ère de la modernisation du mainframe
- Communes, entreprises ? Non, face au RGAA 5, l’IA seule ne rendra pas vos sites accessibles
