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.

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>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>
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!
Es gibt mehrere Möglichkeiten, die CSS-Position zu positionieren
So überprüfen Sie gelöschte Anrufaufzeichnungen
So verwenden Sie die datediff-Funktion
Python führt zwei Listen zusammen
Was sind die Handelsplattformen für virtuelle Währungen?
Enzyklopädie zur Verwendung von Printf
Was sind die MySQL-Update-Anweisungen?
Was ist eine .Xauthority-Datei?