Einzelnen Beitrag anzeigen

Lemmy

Registriert seit: 8. Jun 2002
Ort: Berglen
2.381 Beiträge
 
Delphi 10.4 Sydney
 
#2

AW: SQL - Durchschnittsverbrauch berechnen

  Alt 12. Sep 2012, 14:55
Hi,

zum einen in eine SP verpacken, macht das Leben ungemein leichter und dann würde ich diese Fahrzeuge mit Fahrleistung = 0km rausfiltern:

Code:
Select-....
...

GROUP BY
  ABGABEDATEN.FahrzeugNr,
  FAHRZEUGE.Bezeichnung
Having (Max(ABGABEDATEN.Kilometerstand) - Min(ABGABEDATEN.Kilometerstand))>0
Wenn die dennoch auftauchen sollen, dann ein case:

Code:
SELECT ABGABEDATEN.FahrzeugNr, FAHRZEUGE.Bezeichnung,
  Count(ABGABEDATEN.FahrzeugNr) AS ANZAHL,
  Sum(ABGABEDATEN.AbgabemengeLiter) AS GESAMTMENGE,
  Max(ABGABEDATEN.Kilometerstand) AS MAXKilometerstand,
  Min(ABGABEDATEN.Kilometerstand) AS MINKilometerstand,
  Max(ABGABEDATEN.Kilometerstand) - Min(ABGABEDATEN.Kilometerstand) AS STRECKE,
  case (Max(ABGABEDATEN.Kilometerstand) - Min(ABGABEDATEN.Kilometerstand))
    when 0 then 0
    else
  ((100 / (Max(ABGABEDATEN.Kilometerstand) - Min(ABGABEDATEN.Kilometerstand))) * (Sum(ABGABEDATEN.AbgabemengeLiter) - 
  (SELECT FIRST 1
      T.AbgabemengeLiter AS ERSTE
    FROM
      ABGABEDATEN AS T
    WHERE
      T.FahrzeugNr = ABGABEDATEN.FahrzeugNr AND
      T.DatumUhrzeit >= '01.05.2012' AND
      T.DatumUhrzeit <= '31.12.2012'
    ORDER BY
      T.DatumUhrzeit)))  
   end AS VERBRAUCH
   
FROM
  ABGABEDATEN
  INNER JOIN FAHRZEUGE ON ABGABEDATEN.FahrzeugNr = FAHRZEUGE.FahrzeugNr                          
WHERE
  (ABGABEDATEN.FahrzeugNr = 115) OR
  (ABGABEDATEN.FahrzeugNr = 120) OR
  (ABGABEDATEN.FahrzeugNr = 121 AND
  ABGABEDATEN.DatumUhrzeit >= '01.05.2012' AND
  ABGABEDATEN.DatumUhrzeit <= '31.12.2012')
GROUP BY
  ABGABEDATEN.FahrzeugNr,
  FAHRZEUGE.Bezeichnung
beides aus dem Kopf, sollte aber eigentlich klappen...

Problematisch könnte lediglich die Datenmenge werden, d.h. dass die Abfrage halt langsam wird. In einer SP hast Du da mehr Möglichkeiten...
  Mit Zitat antworten Zitat