Heim > Datenbank > MySQL-Tutorial > Wie kann ich mithilfe von SQL mehrere Tabellen mit unterschiedlichen Strukturen zu einer einzigen einheitlichen Ausgabetabelle kombinieren?

Wie kann ich mithilfe von SQL mehrere Tabellen mit unterschiedlichen Strukturen zu einer einzigen einheitlichen Ausgabetabelle kombinieren?

Barbara Streisand
Freigeben: 2024-12-22 02:00:12
Original
388 Leute haben es durchsucht

How Can I Combine Multiple Tables with Different Structures into a Single Unified Output Table Using SQL?

Kombinieren von Tabellen für eine einheitliche Ausgabe

Tabellen können zusammengeführt werden, um verschiedene Datenmanipulationsergebnisse zu erzielen. Eine häufige Aufgabe besteht darin, Daten aus mehreren Tabellen zur weiteren Analyse in einer einzigen Tabelle zu konsolidieren. Stellen Sie sich das folgende Szenario vor:

Sie haben zwei Tabellen, KnownHours und UnknownHours, die Stundendaten enthalten, die den Gebührennummern zugeordnet sind. Ihr Ziel besteht darin, diese Stunden unabhängig vom Monat in einer einzigen Tabelle mit dem folgenden Format zu gruppieren:

ChargeNum    CategoryID     Hours
111111       1              90
111111       2              50
111111       Unknown        110.5
222222       1              40
222222       Unknown        25.5
Nach dem Login kopieren

In diesem Szenario müssen Sie die Stunden für jede eindeutige Kombination aus ChargeNum und CategoryID (bzw „Unbekannt“ für UnknownHours). Um dies zu erreichen, können Sie den UNION-Operator nutzen:

SELECT ChargeNum, CategoryID, SUM(Hours)
FROM KnownHours
GROUP BY ChargeNum, CategoryID
UNION ALL
SELECT ChargeNum, 'Unknown' AS CategoryID, SUM(Hours)
FROM UnknownHours
GROUP BY ChargeNum
Nach dem Login kopieren

Diese SQL-Anweisung kombiniert die Ergebnisse zweier Abfragen. Die erste Abfrage gruppiert und summiert die Stunden aus der KnownHours-Tabelle nach ChargeNum und CategoryID. Die zweite Abfrage gruppiert und summiert die Stunden aus der UnknownHours-Tabelle nach ChargeNum und weist die Kategorie-ID „Unbekannt“ zu.

Durch die Kombination der Ergebnisse mit UNION ALL enthält die endgültige Tabelle Zeilen aus beiden Abfragen. Die Aggregatfunktion SUM() stellt sicher, dass Stunden für den Abgleich von ChargeNums und CategoryIDs akkumuliert werden.

Mit dieser Technik können Sie Tabellen effizient zusammenführen, um eine konsolidierte Ansicht Ihrer Daten zu erstellen.

Das obige ist der detaillierte Inhalt vonWie kann ich mithilfe von SQL mehrere Tabellen mit unterschiedlichen Strukturen zu einer einzigen einheitlichen Ausgabetabelle kombinieren?. 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