AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi SQL - Durchschnittsverbrauch berechnen
Thema durchsuchen
Ansicht
Themen-Optionen

SQL - Durchschnittsverbrauch berechnen

Ein Thema von user0815 · begonnen am 12. Sep 2012 · letzter Beitrag vom 17. Sep 2012
 
Lemmy

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

AW: SQL - Durchschnittsverbrauch berechnen

  Alt 12. Sep 2012, 13: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
 


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 15:14 Uhr.
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz