Einzelnen Beitrag anzeigen

Medium

Registriert seit: 23. Jan 2008
3.686 Beiträge
 
Delphi 2007 Enterprise
 
#1

[SQL] Zeilen teilweise zu Spalten machen

  Alt 22. Okt 2015, 17:17
Datenbank: MySQL • Version: 5.5.29 • Zugriff über: UniDAC
Huhu DP!

Der Titel ist leider etwas komisch, aber mir fiel nichts ein was mein Anliegen in kurzer Form sinnvoll wiedergeben kann. Daher jetzt ausführlicher:

Gegeben ist eine Tabelle "messliste":
Code:
mDate DATETIME
mID INT
mAVG DOUBLE
mMAX DOUBLE
mMIN DOUBLE
Hier sind Messwerte (Ströme und Spannungen, aber auch Kilowatt, Liter pro Stunde, Wattstunden, ... also praktisch beliebige Werte beliebiger Einheiten) hinterlegt. Die Ströme und Spannungen haben allerdings die besondere Eigenschaft, dass bei denen immer 3 Werte zusammen gehören (3 Phasen). Mein Kunde möchte die gerne in einer anderen Reportform haben als die "einzelnen" Werte wie Kilowattstunden und so, die einfach stumpf aufgelistet werden können.

Das folgende SELECT gibt mir aus o.g. Tabelle immerhin schon mal die gesuchten Werte: SELECT * FROM messliste WHERE (mDate BETWEEN 'fooAND 'bar') AND (mID IN (21,22,23)) Vorausgesetzt dabei: Die IDs 21, 22 und 23 gehören zu einem "Set" Strom oder Spannung, was über das UI schon sichergestellt ist.

Leider erhalte ich die Daten so nur zeilenweise:
Code:
mDate | mID | mAVG | mMAX | mMIN
2015-10-22 10:00:00 | 21 | 0 | 0 | 0
2015-10-22 10:00:00 | 22 | 0 | 0 | 0
2015-10-22 10:00:00 | 23 | 0 | 0 | 0
2015-10-22 10:01:00 | 21 | 0 | 0 | 0
2015-10-22 10:01:00 | 22 | 0 | 0 | 0
2015-10-22 10:01:00 | 23 | 0 | 0 | 0
2015-10-22 10:02:00 | 21 | 0 | 0 | 0
2015-10-22 10:02:00 | 22 | 0 | 0 | 0
2015-10-22 10:02:00 | 23 | 0 | 0 | 0
usw.
Da ich das Ergebnis aber in einen Report verknüpfen will, brauche ich eine Struktur der Art:
Code:
Datum | L1_min | L1_avg | L1_max | L2_min | L2_avg | L2_max | L3_min | L3_avg | L3_max
Ich müsste also irgendwie anhand der 3 unterschiedlichen IDs in Zeilen je 3 Spalten mit den Werten aus mAVG, mMIN und mMAX machen, und dabei das Datum beibehalten (welches gesichert gleich ist pro "3er-Päckchen").
Mir fehlt hier komplett die zündende Idee. Ein Ansatz, den ich ausgestalten kann. Wie kann ich sowas grundsätzlich angehen?
Vielen Dank im Voraus!
"When one person suffers from a delusion, it is called insanity. When a million people suffer from a delusion, it is called religion." (Richard Dawkins)
  Mit Zitat antworten Zitat