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
Libérer: 2025-01-11 07:58:43
original
592 Les gens l'ont consulté

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>
Copier après la connexion

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>
Copier après la connexion

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>
Copier après la connexion

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>
Copier après la connexion

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!

source:php.cn
Déclaration de ce site Web
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
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal