Extraction de données à partir de colonnes XML dans SQL Server
Accéder et récupérer efficacement des points de données spécifiques à partir de colonnes XML dans SQL Server est crucial pour une gestion efficace des données. Ce guide présente des techniques de filtrage des lignes en fonction de la présence de valeurs particulières dans les données XML.
Méthode 1 : Extraction de valeur directe avec value()
Pour localiser les lignes contenant un rôle spécifique dans une colonne XML nommée « Rôles », utilisez la fonction value()
:
<code class="language-sql">SELECT Roles FROM MyTable WHERE Roles.value('(/root/role)[1]', 'varchar(max)') LIKE 'StringToSearchFor';</code>
Cette requête extrait la valeur du premier élément <role>
et la compare à l'aide de l'opérateur LIKE
.
Remarques importantes :
CAST(Roles AS XML)
pour le convertir.<role>
correspondant. Ajustez l'expression XPath ((/root/role)[1]
) pour cibler différents éléments ou attributs selon vos besoins. Par exemple, pour filtrer en fonction d'un attribut CodeSystem
avec la valeur « 2 » :<code class="language-sql">SELECT [data] FROM [dbo].[CodeSystemCodes_data] WHERE CAST([data] as XML).value('(/Utilities.CodeSystems.CodeSystemCodes/@CodeSystem)[1]', 'varchar(max)') = '2';</code>
Méthode 2 : requête améliorée avec CROSS APPLY
et nodes()
Pour une interrogation plus flexible d'éléments XML individuels, utilisez CROSS APPLY
et nodes()
:
<code class="language-sql">SELECT * FROM ( SELECT pref.value('(text())[1]', 'varchar(32)') AS RoleName FROM MyTable CROSS APPLY Roles.nodes('/root/role') AS Roles(pref) ) AS Result WHERE RoleName LIKE '%ga%';</code>
CROSS APPLY
génère une table virtuelle pour chaque élément <role>
, permettant un traitement ligne par ligne. nodes()
extrait chaque élément <role>
et value()
récupère son contenu textuel. Cette approche permet un filtrage et une manipulation des données plus complexes.
Ces méthodes fournissent des solutions robustes pour interroger les valeurs des colonnes XML dans SQL Server, permettant une récupération et un filtrage efficaces des données en fonction de critères spécifiques.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!