


Comment convertir efficacement des colonnes en lignes dans SQL Server ?
SQL Server : Convertir les colonnes en lignes
Dans SQL Server, vous devrez peut-être convertir une table contenant plusieurs colonnes d'indicateurs en une structure de lignes pour chaque indicateur et sa valeur correspondante. Ceci peut être réalisé grâce à plusieurs techniques.
Fonction UNPIVOT
La fonction UNPIVOT est un moyen simple de convertir des colonnes en lignes. Il convertit les colonnes spécifiées en lignes, les noms de colonnes d'origine devenant de nouvelles lignes intitulées « nom de l'indicateur ». La valeur de la colonne d'origine devient la ligne intitulée « valeur de l'indicateur ».
SELECT id, entityId, indicatorname, indicatorvalue FROM yourtable UNPIVOT ( indicatorvalue FOR indicatorname IN (Indicator1, Indicator2, Indicator3) ) unpiv;
Utilisez CROSS APPLY d'UNION ALL
Une autre façon consiste à combiner CROSS APPLY avec UNION ALL :
SELECT id, entityid, indicatorname, indicatorvalue FROM yourtable CROSS APPLY ( SELECT 'Indicator1', Indicator1 UNION ALL SELECT 'Indicator2', Indicator2 UNION ALL SELECT 'Indicator3', Indicator3 UNION ALL SELECT 'Indicator4', Indicator4 ) c (indicatorname, indicatorvalue);
CROSS APPLY en utilisant la clause VALUES
Si votre version de SQL Server le prend en charge, vous pouvez également utiliser la clause VALUES avec CROSS APPLY :
SELECT id, entityid, indicatorname, indicatorvalue FROM yourtable CROSS APPLY ( VALUES ('Indicator1', Indicator1), ('Indicator2', Indicator2), ('Indicator3', Indicator3), ('Indicator4', Indicator4) ) c (indicatorname, indicatorvalue);
SQL dynamique
Pour les tables comportant de nombreuses colonnes d'indicateurs, générer manuellement les instructions SQL nécessaires peut être fastidieux. Dynamic SQL peut automatiser ce processus :
DECLARE @colsUnpivot AS NVARCHAR(MAX), @query AS NVARCHAR(MAX) SELECT @colsUnpivot = STUFF((SELECT ',' + QUOTENAME(C.column_name) FROM INFORMATION_SCHEMA.COLUMNS AS C WHERE C.table_name = 'yourtable' AND C.column_name LIKE 'Indicator%' FOR XML PATH('')), 1, 1, '') SET @query = 'SELECT id, entityId, indicatorname, indicatorvalue FROM yourtable UNPIVOT ( indicatorvalue FOR indicatorname IN (' + @colsunpivot +') ) u' EXEC sp_executesql @query;
Ces technologies fournissent des méthodes flexibles de conversion de colonnes en lignes dans SQL Server et peuvent s'adapter à différentes structures de tables et besoins en données.
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!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

Réduisez l'utilisation de la mémoire MySQL dans Docker

Comment modifier une table dans MySQL en utilisant l'instruction ALTER TABLE?

Comment résoudre le problème de MySQL ne peut pas ouvrir la bibliothèque partagée

Exécutez MySQL dans Linux (avec / sans conteneur Podman avec phpmyadmin)

Exécuter plusieurs versions MySQL sur macOS: un guide étape par étape

Quels sont les outils de GUI MySQL populaires (par exemple, MySQL Workbench, PhpMyAdmin)?

Comment configurer le cryptage SSL / TLS pour les connexions MySQL?
