Heim > Datenbank > MySQL-Tutorial > Wie transponiere ich Zeilen in Spalten in BigQuery?

Wie transponiere ich Zeilen in Spalten in BigQuery?

Mary-Kate Olsen
Freigeben: 2025-01-05 18:33:43
Original
452 Leute haben es durchsucht

How to Transpose Rows into Columns in BigQuery?

Zeilen in Spalten in BigQuery transponieren: Eine Pivoting-Implementierung

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.

Struktur der Eingabetabelle

Stellen Sie zunächst sicher, dass Ihre Eingabetabelle die folgenden Spalten enthält:

  • Schlüssel: Die Spalte, die jeweils die Kategorie angibt Zeile.
  • Wert: Der Wert, der dem Schlüssel entspricht.

Zusätzlich benötigen Sie eine Spalte, die Zeilen gruppiert, die zu einer einzigen zusammengefasst werden sollen Zeile in der Ausgabe.

Schritt 1: Eingabedaten in eine transponierte Abfragezeichenfolge konvertieren

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
) 
Nach dem Login kopieren

Schritt 2: Ausführen der transponierten Abfrage

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
Nach dem Login kopieren

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

Hinweis

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!

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