Maison > base de données > tutoriel mysql > Comment diviser les données d'une colonne en plusieurs lignes dans SQL ?

Comment diviser les données d'une colonne en plusieurs lignes dans SQL ?

Patricia Arquette
Libérer: 2025-01-05 07:03:42
original
377 Les gens l'ont consulté

How to Split a Column's Data into Multiple Rows in SQL?

Comment diviser les données d'une colonne en lignes dans SQL ?

Lorsque vous travaillez avec des bases de données relationnelles, vous pouvez rencontrer des situations dans lesquelles vous devez diviser le les données d'une seule colonne en plusieurs lignes. Cette technique est particulièrement utile pour des scénarios tels que la séparation d'une liste d'éléments séparés par des virgules en lignes individuelles.

Pour y parvenir, vous pouvez exploiter la puissance des fonctions de manipulation de chaînes dans SQL. Explorons deux méthodes pour diviser les données d'une colonne en lignes :

1. Utilisation d'une fonction de fractionnement :

Vous pouvez créer une fonction de fractionnement personnalisée pour diviser les données de la colonne en fonction d'un délimiteur spécifique, tel qu'une virgule ou un point-virgule. Voici un exemple de fonction que vous pouvez utiliser :

CREATE FUNCTION [dbo].[Split](@String VARCHAR(MAX), @Delimiter CHAR(1))
RETURNS @temptable TABLE (items VARCHAR(MAX))
AS
BEGIN
    DECLARE @idx INT
    DECLARE @slice VARCHAR(8000)

    SELECT @idx = 1
    IF LEN(@String)<1 OR @String IS NULL RETURN

    WHILE @idx!= 0
    BEGIN
        SET @idx = CHARINDEX(@Delimiter,@String)
        IF @idx!=0
            SET @slice = LEFT(@String,@idx - 1)
        ELSE
            SET @slice = @String

        IF(LEN(@slice)>0)
            INSERT INTO @temptable(Items) VALUES(@slice)

        SET @String = RIGHT(@String,LEN(@String) - @idx)
        IF LEN(@String) = 0 BREAK
    END

    RETURN
END;
Copier après la connexion

2. Utilisation d'un CTE récursif :

Vous pouvez également utiliser une expression de table commune (CTE) récursive pour obtenir le même résultat. Voici une solution CTE :

WITH cte (code, DeclarationItem, Declaration) AS
(
  SELECT Code,
    CAST(LEFT(Declaration, CHARINDEX(',',Declaration+',')-1) AS VARCHAR(50)) DeclarationItem,
         STUFF(Declaration, 1, CHARINDEX(',',Declaration+','), '') Declaration
  FROM yourtable
  UNION ALL
  SELECT code,
    CAST(LEFT(Declaration, CHARINDEX(',',Declaration+',')-1) AS VARCHAR(50)) DeclarationItem,
    STUFF(Declaration, 1, CHARINDEX(',',Declaration+','), '') Declaration
  FROM cte
  WHERE Declaration > ''
)
SELECT code, DeclarationItem
FROM cte
Copier après la connexion

Exemple d'utilisation :

Pour diviser la colonne « Déclaration » de la table « votretable » en lignes individuelles, vous pouvez utiliser soit des méthodes ci-dessus. Par exemple :

SELECT t1.code, s.items AS declaration
FROM yourtable t1
OUTER APPLY dbo.split(t1.declaration, ',') s
Copier après la connexion

Cette requête produira un résultat dans lequel la colonne « Déclaration » est divisée en lignes distinctes pour chaque élément.

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