Maison >base de données >tutoriel mysql >Comment diviser des chaînes séparées par des virgules dans SQL Server 2012 ?
Remplacement de la fonction STRING_SPLIT dans SQL Server 2012
La fonction STRING_SPLIT introduite dans SQL Server 2016 offre un moyen pratique de diviser une chaîne délimitée par des virgules en éléments individuels. Cependant, pour ceux qui utilisent SQL Server 2012, une solution de contournement est requise en raison du manque de cette fonctionnalité.
Méthodes de fractionnement alternatives
Pour diviser les valeurs séparées par des virgules dans SQL Server 2012, envisagez d'utiliser la méthode XML suivante avec CROSS APPLY :
<code class="language-sql">SELECT Split.a.value('.', 'NVARCHAR(MAX)') AS DATA FROM ( SELECT CAST('<X>'+REPLACE(@ID, ',', '</X><X>')+'</X>' AS XML) AS String ) AS A CROSS APPLY String.nodes('/X') AS Split(a);</code>
Exemple d'utilisation
Supposons que le paramètre @ID contienne une liste de nombres séparés par des virgules :
<code class="language-sql">@ID varchar = '1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20';</code>
Exécutez une requête pour diviser le @ID en ses composants :
<code>DATA 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20</code>
Exemples avancés
Cette méthode peut être étendue pour créer des requêtes plus complexes. Par exemple, la requête suivante divise les @ID et @Marks (une autre liste séparée par des virgules) en une table appelée @StudentsMark et associe chaque ID à son score correspondant :
<code class="language-sql">DECLARE @ID NVARCHAR(300)= '1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20'; DECLARE @Marks NVARCHAR(300)= '0,1,2,5,8,9,4,6,7,3,5,2,7,1,9,4,0,2,5,0'; DECLARE @StudentsMark TABLE (id NVARCHAR(300), marks NVARCHAR(300) ); ;WITH CTE AS ( SELECT Split.a.value('.', 'NVARCHAR(MAX)') id, ROW_NUMBER() OVER(ORDER BY ( SELECT NULL )) RN FROM ( SELECT CAST('<X>'+REPLACE(@ID, ',', '</X><X>')+'</X>' AS XML) AS String ) AS A CROSS APPLY String.nodes('/X') AS Split(a)), CTE1 AS ( SELECT Split.a.value('.', 'NVARCHAR(MAX)') marks, ROW_NUMBER() OVER(ORDER BY ( SELECT NULL )) RN FROM ( SELECT CAST('<X>'+REPLACE(@Marks, ',', '</X><X>')+'</X>' AS XML) AS String ) AS A CROSS APPLY String.nodes('/X') AS Split(a)) INSERT INTO @StudentsMark SELECT C.id, C1.marks FROM CTE C LEFT JOIN CTE1 C1 ON C1.RN = C.RN; SELECT * FROM @StudentsMark;</code>
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!