Maison >base de données >tutoriel mysql >Comment diviser des chaînes séparées par des virgules dans SQL Server 2012 ?

Comment diviser des chaînes séparées par des virgules dans SQL Server 2012 ?

Mary-Kate Olsen
Mary-Kate Olsenoriginal
2025-01-11 07:58:43582parcourir

How to Split Comma-Separated Strings in 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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn