Il est aussi possible de vérifier que le document soit « valide » à partir d’un XML Schéma (XSD).
Validation des données avec un schéma XML
On comprendra qu’un XSD permet de délocaliser une partie de l’intelligence de l’application : quoi de plus simple que de valider des règles métier avec un Schéma XML !
La validation à partir d’un DTD ne sera pas possible, mais il existe de nombreux outils gratuits qui permettent la conversion d’un DTD en XSD (ex TRANG).
Par exemple, si un XML Schéma dit qu’une valeur de tag devrait être un nombre et si le fichier XML possède une lettre, le fichier XML, même bien formé, sera non valide. Il est donc très facile de contrôler le bon état d’un document avant son intégration dans DB2, mais ce n’est pas une obligation.
Avant qu’un schéma XML puisse être utilisé pour valider un document XML, ce dernier doit être enregistré dans le « XML Schema Repository » appelé XSR. Cette étape préalable sera accomplie grâce à de nouvelles procédures stockées intégrés à DB2 : XSR_REGISTER et XSR_COMPLETE comme montré en figure 4.
Un appel à la procédure XSR_COMPLETE est nécessaire afin d’achever l’enregistrement du XSD, car il est possible de combiner de multiples schémas XML (les fusionner) en un unique XSR en utilisant la procédure XSR_ADDSCHEMADOC. Ceci offre la possibilité de valider un flux XML à partir de plusieurs schémas en une seule passe.
Mais dans quel cas ? Tout simplement si votre flux XML évolue avec l’ajout de nouvelles informations, vous pourrez valider ces nouvelles informations avec un nouveau schéma partiel relatif à ces nouvelles données sans tout recommencer.
A l’inverse, la procédure XSR_REMOVE permet la suppression d’un objet *SQLXSR.
Le contenu du référentiel de schémas XML (XSR) peut être interrogé en lançant une requête SQL sur QSYS2.XSROBJECTS faisant dorénavant partie des références croisées de DB2 ou directement via iSeries Navigator.
Pour insérer dans une colonne XML un document XML en demandant sa validation, il faudra utiliser l’ordre XMLVALIDATE comme montré en figure 5.
Pourquoi ne pas pouvoir valider directement un XML dans une colonne à partir d’un XSD stocké dans l’IFS sans passer par un XSR ? Simplement pour des questions de performances qui seraient impactées si DB2 devait à chaque fois accéder à un fichier externe stocké dans l’IFS.
Téléchargez cette ressource

État des lieux de la réponse à incident de cybersécurité
Les experts de Palo Alto Networks, Unit 42 et Forrester Research livrent dans ce webinaire exclusif leurs éclairages et stratégies en matière de réponses aux incidents. Bénéficiez d'un panorama complet du paysage actuel de la réponse aux incidents et de sa relation avec la continuité de l'activité, des défis auxquels font face les entreprises et des tendances majeures qui modèlent ce domaine. Un état des lieux précieux pour les décideurs et professionnels IT.
Les articles les plus consultés
Les plus consultés sur iTPro.fr
- La souveraineté numérique pour renforcer la cybersécurité
- Perspectives IA, Cybersécurité et STaaS en 2025
- Impact des outils d’IA sur la satisfaction, le niveau de stress et le bien-être !
- La portabilité des données, un élément essentiel pour soutenir l’émergence des clouds souverains
- Passer d’une logique de productivité à une recherche d’utilité
