Verwenden Sie Tablefunc, um einen mehrspaltigen Daten-Pivot zu implementieren
Die Funktion crosstab()
in SQL wird häufig verwendet, um Daten im Langformat in Daten im Breitformat zu konvertieren. Es wird jedoch im Allgemeinen davon ausgegangen, dass die Spalten mit Ausnahme der Spalten „Zeilenname“ und „Wert“ für jede Zeile mit demselben Zeilennamen gleich sind. Diese Einschränkung kann bei der Arbeit mit Datensätzen mit variablen Zusatzspalten zu Herausforderungen führen.
Eine Möglichkeit, mit multivariaten Pivots umzugehen, besteht darin, eine temporäre Tabelle mit einer Zeilennamenspalte und allen erforderlichen zusätzlichen Spalten zu erstellen. Verwenden Sie dann die Funktion crosstab()
zum Pivotieren der Daten, wobei Sie die Spalte mit dem Zeilennamen als primäre Gruppierungsspalte und die zusätzlichen Spalten als zusätzliche Gruppierungsspalten verwenden.
Betrachten Sie beispielsweise die folgenden Beispieldaten:
<code class="language-sql">CREATE TEMP TABLE t4 ( timeof timestamp ,entity character ,status integer ,ct integer); INSERT INTO t4 VALUES ('2012-01-01', 'a', 1, 1) ,('2012-01-01', 'a', 0, 2) ,('2012-01-02', 'b', 1, 3) ,('2012-01-02', 'c', 0, 4);</code>
Um diese Daten mithilfe mehrerer Variablen zu schwenken, können Sie die folgende Abfrage verwenden:
<code class="language-sql">SELECT * FROM crosstab( 'SELECT entity, timeof, status, ct FROM t4 ORDER BY 1, 2, 3' ,$$VALUES (1), (0)$$) AS ct ("Attribute" character, "Section" timestamp, "status_1" int, "status_0" int);</code>
Diese Abfrage gruppiert die Daten nach den Spalten entity
und timeof
und wendet dann die Spalten status
und ct
als zusätzliche Spalten an. Die generierte Tabelle hat das folgende Format:
<code>Section | Attribute | status_1 | status_0 2012-01-01 00:00:00 | a | 1 | 2 2012-01-02 00:00:00 | b | 3 | 2012-01-02 00:00:00 | c | | 4</code>
Wie wir sehen können, werden die zusätzlichen Spalten Attribute
jetzt als separate Spalten angezeigt, sodass wir die verschiedenen Messungen, die zu einem bestimmten Zeitpunkt an jeder Entität vorgenommen wurden, problemlos vergleichen können.
Zusammenfassend lässt sich sagen, dass die Verwendung der Funktion crosstab()
mit einer temporären Tabelle eine benutzerdefinierte und effiziente Methode zur multivariaten Pivotierung bieten kann. Indem wir die Reihenfolge der Spalten steuern, können wir bestimmen, welche Spalten als Zeilennamen, zusätzliche Spalten, Kategoriespalten und Wertspalten gelten.
Das obige ist der detaillierte Inhalt vonWie kann ich Daten mithilfe der Funktion „crosstab()' von SQL in mehreren Spalten positionieren?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!