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...