Heim > Datenbank > MySQL-Tutorial > Hauptteil

Wie kann ich Daten in MySQL dynamisch Pivotieren, wenn die Spalten unbekannt sind?

Linda Hamilton
Freigeben: 2024-10-30 23:12:30
Original
396 Leute haben es durchsucht

How to Dynamically Pivot Data in MySQL When Columns Are Unknown?

MySQL Dynamic Cross Tab

In Szenarien, in denen die Anzahl der Spalten in einer Kreuztabellenabfrage unbekannt ist, können herkömmliche MySQL-Kreuztabellenlösungen verwendet werden kann zu kurz kommen. In diesem Artikel werden zwei Ansätze zur Bewältigung dieser Herausforderung untersucht.

1. Dynamische Abfragekonstruktion

Diese Methode beinhaltet das Abrufen eindeutiger Werte für die unbekannte Spalte (z. B. Weg) und das anschließende dynamische Erstellen einer Abfrage mit der entsprechenden Anzahl von Spalten:

$pdo->query("SELECT DISTINCT `way` FROM `MyTable`");
foreach ($rows as $row) {
  $way = (int) $row["way"];
  $way_array[] = "MAX(IF(`way`=$way, `time`)) AS way_$way";
}
$pivotsql = "SELECT stop, " . join(", ", $way_array) . "FROM `MyTable` GROUP BY `stop`";
Nach dem Login kopieren

Dies Der Ansatz erfordert zusätzlichen Anwendungscode, um die Abfrage dynamisch zu erstellen, vermeidet jedoch komplexe SQL-Anweisungen und ist flexibler für die Verarbeitung einer variablen Anzahl von Spalten.

2. Zeilenweises Pivotieren

Alternativ können Sie die Daten Zeile für Zeile abfragen und das Pivotieren im Anwendungscode durchführen:

$stoparray = array();
foreach ($pdo->query("SELECT * FROM `MyTable`") as $row) {
  $stopkey = $row["stop"];
  if (!array_key_exists($stopkey, $stoparray)) {
    $stoparray[$stopkey] = array("stop"=>$stopkey);
  }
  $waykey = "way_" . $row["way"];
  $stoparray[$stopkey][$waykey] = $row["time"];
}
Nach dem Login kopieren

Dieser Ansatz erfordert mehr Nachbearbeitung in der Anwendung, ermöglicht aber eine größere Flexibilität bei der Pivotierung der Daten.

Das obige ist der detaillierte Inhalt vonWie kann ich Daten in MySQL dynamisch Pivotieren, wenn die Spalten unbekannt sind?. 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
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!