AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Zeiten einer Datenbank addieren

Zeiten einer Datenbank addieren

Ein Thema von DoktorD · begonnen am 16. Dez 2005 · letzter Beitrag vom 16. Dez 2005
Antwort Antwort
DoktorD

Registriert seit: 13. Dez 2005
153 Beiträge
 
#1

Zeiten einer Datenbank addieren

  Alt 16. Dez 2005, 22:21
Datenbank: SQL • Zugriff über: Query
Hallo!!!

Ich habe ein Problem.

In meiner SQL Datenbank befindet sich eine Spalte mit gestoppten Zeiten. Die Felder in der Datenbank sind als "Time" angelegt.

Außerhalb dieser Tabelle will ich nun die Zeiten addieren. Das funktioniert ganz gut, aber sobald 24 Stunden überschritten werden, fängt er wieder bei null an. Ich will aber das er dann alles in Stunden umrechnet (z.B 65:31:34).

Kann mir irgendjemand weiterhelfen??? Bin zwar kein Anfänger mehr, aber wenn es geht, beschreibt es ziemlich genau und einfach.

Delphi-Quellcode:
function TForm1.CalcSumm():boolean;
var
  Summe:TDateTime;
  Zaehler:Integer;
Begin
  Query1.First;
  Summe := 0;
  Zaehler:=0;
  while not Query1.Eof do
  begin
    Summe := Summe + Query1.FieldValues['Zeit'];
    Query1.Next;
    Zaehler:= Zaehler+1
  end;
  lbAnzahl.Caption:=IntToStr(Zaehler);
  Query1.First;
  lbSumme.Caption:=TimeToStr(Summe); // Hier die fertige Summe
end;
Vielen Dank für Eure Mühe!!!
  Mit Zitat antworten Zitat
Benutzerbild von Jelly
Jelly

Registriert seit: 11. Apr 2003
Ort: Moestroff (Luxemburg)
3.741 Beiträge
 
Delphi 2007 Professional
 
#2

Re: Zeiten einer Datenbank addieren

  Alt 16. Dez 2005, 22:35
Ganz herzliches Willkommen hier im besten Forum

Zu deinem Problem:
1. Warum berechnest Du deine Summe in Delphi. Du durchläufst deine gesamte Datenmenge, nur um die Summer zu berechnen. Wenn Du 100000 hast, dauert das ne halbe Ewigkeit... Deshalb erst mal besser:
select sum(Zeit) as GesamtZeit from DeineTabelle In query1.FieldValues['Gesamtzeit'] steht dann als TDateTime deine Summe.

2. Dein Problem ist aber im Grunde die Darstellung. Da musst Du dich schon selbst drum kümmern. Da Du ja kein Anfänger mehr bist, sollte Folgendes als Stütze helfen:
Delphi speichert die Daten und Zeiten in einem Float, auch wenn Du TDateTime verwendest. Der Teil vor dem komma sind die Tage, die dahinter die Stunden... Hast du also bsp. 60 Stunden, so sind das im Grunde genau 2,5 Tage
Also:
Delphi-Quellcode:
function FormatTime (T : TDateTime) : string ;
var
 h, m, s, ms : word ;
begin
     DecodeTime (T,h,m,s,ms) ;
     h := h + Trunc(T)*24 ;
     Result := Format ('%.3d:%.2d%.2d',[h,m,s]) ;
end ;
In Delphi gibts bestimmt dafür auch eine fertige Funktion, aber ich denk so sollte das Prinzip leichter verständlich sein, was ein TDateTime überhaupt für Delphi darstellt.
  Mit Zitat antworten Zitat
omata

Registriert seit: 26. Aug 2004
Ort: Nebel auf Amrum
3.154 Beiträge
 
Delphi 7 Enterprise
 
#3

Re: Zeiten einer Datenbank addieren

  Alt 16. Dez 2005, 22:36
Moin,

bei Datenbank hast du nur SQL geschrieben. Welche Datenbank den nun genau?

MfG
Thorsten
  Mit Zitat antworten Zitat
DoktorD

Registriert seit: 13. Dez 2005
153 Beiträge
 
#4

Re: Zeiten einer Datenbank addieren

  Alt 16. Dez 2005, 23:23
Super, Danke!!!! Es funktioniert.

PS: Datenbank ist Paradox7
  Mit Zitat antworten Zitat
Themen-Optionen Thema durchsuchen
Thema durchsuchen:

Erweiterte Suche
Ansicht

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 10:46 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz