SQL Server et le XML - SQL/NoSQL - Programmation
Marsh Posté le 26-07-2005 à 12:10:28
Bravo,
Ce qui serait bien c'est que tu fasses une partie pour récupérer ton XML dans un fichier (avec la commande BCP par exemple) pour que ce dernier soit exploitable. Je peux t'aider si tu veux. ;-)
Marsh Posté le 26-07-2005 à 12:17:24
madkane a écrit : Bravo, |
Merci.
T'en fais pas ca viendra.
Marsh Posté le 26-07-2005 à 14:23:26
Truc pour ou moins en rapport... L'autre jour, j'ai trouvé qu'on peut créer un document "tpl" contenant une page HTML (ou XML) template, et via une procédure, on peut générer, à intervals réguliers, des pages HTML résultat de la fusion de ce fichier TPL avec les résultats d'une série de requêtes.
Ca me semble carrément bien pour générer une version statique d'un site très lourd de contenu, sans pour autant coder une usinde à gaz pour mettre à jour les pages par la suite.
Seulement, j'ai fait ce qu'ils marquent dans l'exemple (que j'ai recopié en fait) et j'obtiens une erreur.
Je suis sous NT4, ça vient peut-être de là, mais bon...
Marsh Posté le 26-07-2005 à 14:24:25
Voir "sp_makewebtask"
Marsh Posté le 26-07-2005 à 14:35:09
En effet c'est vraiment pas mal comme truc....enfin ca a l'air.
Marsh Posté le 26-07-2005 à 10:24:04
Bon alors je vais essayer de vous présenter quelques utilisations du XML avec le SGBD de Microsoft.
Attention, c'est juste un 'papier' d'information, ca veut dire que pour que cela soit vraiment utile pour vous, il vous faudra aussi chercher de votre coté.
Ce que je vais présenter:
Les resultats en XML:
Une fonction intéressante de SQL Server, c'est la possibilité de sortir les résultats d'un SELECT sous forme de XML.
Pour cela on utilisera la clause 'FOR XML'. Cette clause est accompagnée de 3 options:
RAW
AUTO
EXPLICIT
L'option RAW:
Cette option permet d'afficher les tuples du résultat sous forme d'élèments XML. Chaque élèment du tuple est mappé en un attibut.
Exemple:
Et en résultat:
Remarque: Si une valeur est nulle alors n'est pas mappée en tant qu'élèment.
L'option AUTO:
Avec cette option, le résultat n'est plus sous forme de simple élèments mais sous forme de noeuds XML.
Exemple:
Et en résultat:
Comme on peut le remarquer, les attributs sont associés dans l'ordre de gauche à droite du Select.(Je suis pas certain que tout le monde m'est compris...)
Bon....Exemple:
Et en résultat:
Même remarque que pour l'option RAW, les colonnes dont la valeur est nulle ne sont pas mappées.
Autre point important, souvent il n'y a aucun 'root node', de ce fait le document XML en sortie n'est pas valide...c'est pour cela qu'est faite l'option EXPLICIT.
L'option EXPLICIT:
Bon alors pour utiliser cette option, il va falloir séparer notre précédente requête en 2 requêtes et nous utiliserons ensuite un UNION.
Il est nécéssaire ici de séparer la requête pour la raison suivante: chacune des requêtes correspondra à un niveau dans l'arbre XML de sortie.
Exemple:
Et en résultat:
Ce XML est directment exploitable par, par exemple du C#.
XML: un type de données
Par ce titre je veux dire que l'on peut stocker du XML dans une BDD. Il est certain que cette fonction existe depuis SQL Server 2000 mais cela été quelque peu difficile et peu pratique à utiliser. Maintenant cela devient un jeu d'enfant.
Bon un exemple:
Création de notre table:
C'est cette ligne qui spécifie que nous avons à faire à du XML:
Insertion des données:
SELECT:
On s'amuse avec XPATH:
J'espère que tout le monde a à peu près compris et que cela permettra à certains d'éviter des heures de google.
P.S: Toute remarque est la bienvenue.
Message édité par cesarr89 le 26-07-2005 à 14:12:37