Durch das Transponieren von Zeilen in Spalten, auch Pivotieren genannt, können Sie Schlüssel-Wert-Paare in eine neue Tabelle konvertieren Dabei werden die Schlüssel zu Spaltennamen und die Werte werden in die entsprechenden Zellen eingefügt. Obwohl BigQuery keine nativen Pivotfunktionen unterstützt, können Sie dies dennoch mit einem unkomplizierten Ansatz erreichen.
Stellen Sie zunächst sicher, dass Ihre Eingabetabelle die folgenden Spalten enthält:
Zusätzlich benötigen Sie eine Spalte, die Zeilen gruppiert, die zu einer einzigen zusammengefasst werden sollen Zeile in der Ausgabe.
In Schritt 1 erstellen wir eine Abfragezeichenfolge, die bei Ausführung die transponierte Abfrage generiert. Führen Sie die folgende Abfrage aus:
SELECT 'SELECT id, ' + GROUP_CONCAT_UNQUOTED( 'MAX(IF(key = "' + key + '", value, NULL)) as [' + key + ']' ) + ' FROM yourTable GROUP BY id ORDER BY id' FROM ( SELECT key FROM yourTable GROUP BY key ORDER BY key )
Kopieren Sie das Ergebnis aus Schritt 1 und führen Sie es als reguläre Abfrage aus. Dadurch wird eine Tabelle mit den transponierten Daten erstellt:
SELECT id, MAX(IF(key = "channel_id", value, NULL)) AS [channel_id], MAX(IF(key = "channel_title", value, NULL)) AS [channel_title], MAX(IF(key = "examId", value, NULL)) AS [examId], MAX(IF(key = "postId", value, NULL)) AS [postId], MAX(IF(key = "youtube_id", value, NULL)) AS [youtube_id] FROM yourTable GROUP BY id ORDER BY id
Die resultierende Tabelle hat die folgende Struktur:
id | channel_id | channel_title | examId | postId | youtube_id |
---|---|---|---|---|---|
1 | UCiDKcjKocimAO1tV | Mahendra Guru | 72975611-4a5e-11e5 | 1189e340-b08f | ugEGMG4-MdA |
2 | UCODeKM_D6JLf8jJt | Ab Live | 72975611-4a5e-11e5 | 0c3e6590-afeb | 3TNbtTwLY0U |
Wenn Ihre Tabelle eine große hat Anzahl der Spalten können Sie Schritt 1 überspringen, indem Sie die transponierte Abfrage manuell erstellen. Schritt 1 bietet jedoch eine schnelle und bequeme Möglichkeit, die Abfrage dynamisch zu generieren.
Das obige ist der detaillierte Inhalt vonWie transponiere ich Zeilen in Spalten in BigQuery?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!