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;
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
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
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!