Pour éviter des UNIONs, on peut créer une table temporaire contenant les colonnes que requiert FOR XML EXPLICIT, puis la peupler avec les lignes appropriées. Autrement dit, on crée une table temporaire ayant la structure de la table universelle qu'illustre la figure 5. En utilisant le code SQL suivant
Utiliser une table temporaire
pour
créer une table temporaire appelée
#TreeXML, on peut renvoyer les données
en format XML:
SELECT * FROM #TreeXML
FOR XML EXPLICIT
Pour des requêtes plus complexes,
cette technique dispense d’une grande
instruction SQL contenant plusieurs
instructions UNION. Comme nous le
verrons plus loin, elle est également intéressante
parce qu’on peut étendre le
code pour traiter un nombre variable
de colonnes, comme dans l’exemple
de structure arborescente. L’inconvénient
est que la création de tables
temporaires est une opération généralement
plus lente que l’instruction
UNION relativement efficace. Par
conséquent, on réservera cette technique
à des cas plus complexes.
Le listing 4 montre le code complet
servant à générer une procédure stockée
qui créera la hiérarchie XML complète
que l’on voit figure 2. La procédure
a deux étapes. La première crée
une table temporaire qui a les mêmes
noms de colonnes que la table universelle.
Le code peuple ensuite la table
un niveau à la fois. L’élément de niveau
supérieur (Fred) est ajouté d’abord ; à
noter qu’il faut une jointure entre les
tables Relationship et Employee pour
extraire tous les éléments de données.
Le code ajoute ensuite tous les employés
qui reportent à Fred. Le code
effectue un self join en retour vers la
table temporaire pour obtenir des détails
des colonnes Employee!1!EmployeeID
et Employee!1!FirstName,
que vous venez de calculer. Vous pouvez
faire une jointure en retour au niveau
précédent chaque fois que vous
insérez un nouveau niveau, ce qui vous
dispense d’un nombre de jointures en
constante augmentation comme avec
la solution UNIONs des listings 2 et 3.
L’exécution de cette procédure stockée
renvoie le XML requis que montre
la figure 2.
Téléchargez cette ressource
Reporting Microsoft 365 & Exchange
Comment bénéficier d’une vision unifiée de vos messageries, protéger vos données sensibles, vous conformer aisément aux contraintes réglementaires et réduire votre empreinte carbone ? Testez la solution de reporting complet de l’utilisation de Microsoft 365 et Exchange en mode Cloud ou on-premise.
Les articles les plus consultés
Les plus consultés sur iTPro.fr
- Connaître son client : exploiter les API des réseaux pour offrir des services personnalisés et sur mesure
- Architecte cloud : applications de chatbot & Azure OpenAI Service
- Le LLMjacking : quand les cyberattaques utilisent illicitement des comptes LLM
- Les identités des développeurs doivent être prises en compte !
- Architecture de données ouverte : un levier essentiel pour maximiser les bénéfices de l’IA générative