Heim > Datenbank > MySQL-Tutorial > Wie kann man Zeilen in SQL ohne Aggregation dynamisch in Spalten umwandeln?

Wie kann man Zeilen in SQL ohne Aggregation dynamisch in Spalten umwandeln?

Patricia Arquette
Freigeben: 2025-01-08 00:51:42
Original
197 Leute haben es durchsucht

Dieser SQL-Code wandelt Zeilen dynamisch in Spalten um, ohne Datentypen zu verlieren, eine Leistung, die häufig Aggregationsfunktionen erfordert. Formulieren wir es aus Gründen der Klarheit und besseren Lesbarkeit um.

How to Dynamically Pivot Rows to Columns in SQL Without Aggregation?

Dynamisches Pivotieren von Zeilen in Spalten in SQL: Eine typerhaltende Lösung

Standard-SQL-PIVOT-Operationen erfordern normalerweise eine Aggregatfunktion (wie MAX oder MIN), was zu Datenverlust oder Typerzwingung führen kann. Dieses Beispiel zeigt einen dynamischen SQL-Ansatz zum Pivotieren von Zeilen in Spalten unter Beibehaltung der ursprünglichen Datentypen und der Verarbeitung von bis zu 12 Testnamen.

Die Herausforderung besteht darin, eine Tabelle mit einer variablen Anzahl von Testnamen (bis zu 12) und gemischten Datentypen in eine Tabelle umzuwandeln, in der jeder Testname zu einer Spalte wird. Um dieser Variabilität gerecht zu werden, ist eine dynamische Lösung erforderlich.

Die dynamische SQL-Lösung

Diese Lösung nutzt geschickt dynamisches SQL, um die Pivot-Abfrage basierend auf den Daten selbst zu erstellen.

<code class="language-sql">DECLARE @cols AS NVARCHAR(MAX),
    @query  AS NVARCHAR(MAX);

SELECT @cols = STUFF((SELECT distinct ',' + QUOTENAME(TEST_NAME) 
                    FROM yourtable
            FOR XML PATH(''), TYPE
            ).value('.', 'NVARCHAR(MAX)') 
        ,1,1,'');

SET @query = 'SELECT sbno,' + @cols + '
             FROM 
             (
                SELECT test_name, sbno, val
                FROM yourtable
             ) x
             PIVOT 
             (
                MAX(val)
                FOR test_name IN (' + @cols + ')
             ) p;';

EXECUTE(@query);</code>
Nach dem Login kopieren

Der Code erstellt zunächst eine durch Kommas getrennte Liste von Spaltennamen (@cols) aus den eindeutigen TEST_NAME-Werten. Anschließend wird die PIVOT-Abfrage (@query) erstellt und dabei MAX(val) als Aggregationsfunktion verwendet. Obwohl MAX verwendet wird, bleiben die Originaldaten effektiv erhalten, da wir innerhalb jedes SBNO auf eindeutige Werte setzen. Abschließend wird die generierte Abfrage ausgeführt.

Illustrative Ausgabe

Die Ausgabetabelle verfügt über eine Spalte für jeden eindeutigen Testnamen, die mit den entsprechenden Werten aus der Originaltabelle gefüllt ist und deren ursprüngliche Datentypen beibehält:

<code>| SBNO | TEST1 | TEST2 |  TEST3 |
---------------------------------
|    1 | 0.304 |   2.3 |   PASS |
|    2 |  0.31 |   2.5 |   PASS |
|    3 | 0.306 |   2.4 | (null) |</code>
Nach dem Login kopieren

Diese Methode verarbeitet effizient eine unterschiedliche Anzahl von Testnamen und verschiedene Datentypen und bietet eine robuste Lösung für dynamisches Pivotieren in SQL. Denken Sie daran, yourtable durch den tatsächlichen Namen Ihrer Tabelle zu ersetzen.

Das obige ist der detaillierte Inhalt vonWie kann man Zeilen in SQL ohne Aggregation dynamisch in Spalten umwandeln?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage