Delphi-PRAXiS
Seite 1 von 3  1 23      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Konvertierungsfehler bei Funktion (https://www.delphipraxis.net/185420-konvertierungsfehler-bei-funktion.html)

khh 8. Jun 2015 15:58

Datenbank: Firebird • Version: 2.1 • Zugriff über: Zeos

Konvertierungsfehler bei Funktion
 
Hallo zusammen,
mit Auszug:
Delphi-Quellcode:
   FQuery1.SQL.add('sum (feld1 - feld1) as ergebnis');
  gesamtzeit := FQuery1.FieldByName('ergebnis').AsDateTime;
möchte ich das Ergebnis einer Subtraktion summieren.
Das funktionier m.E. auch, bis ich bei der Zuweisung an "gesamtzeit" einen error:
invalid Typconversion bekomme.
gesamtzeit ist vom Type TdateTime.

Was läuft falsch?

EDIT : sorry, klar Schreibfehler, muss feld1 - feld2 heissen

mkinzler 8. Jun 2015 16:11

AW: Konvertierungsfehler bei Funktion
 
ein TDateTime enthält einen Zeitpunkt ( als Uhrzeit). Subtrahiert man zwei Zeitwerte enzhält man eine Zeitspanne, Dies ist keine Zeitpunkt mehr. Erst recht wenn man diese Werte anschliessend addiert.
Welche Uhrzeit entspricht den z.B. 10 Min + 8 Min +5 Min?

p80286 8. Jun 2015 16:41

AW: Konvertierungsfehler bei Funktion
 
Zitat:

Zitat von mkinzler (Beitrag 1304554)
Subtrahiert man zwei Zeitwerte enzhält man eine Zeitspanne, Dies ist keine Zeitpunkt mehr.

Woher weißt Du daß es sich um eine Zeitspannne handelt?
Ich bin automatisch davon Ausgegangen, das in Feld1,Feld2 Schreibfehler? ein Zeitpunkt seine Heimat gefunden hat.

Gruß
K-H

mkinzler 8. Jun 2015 17:38

AW: Konvertierungsfehler bei Funktion
 
Imho entsteht eine Zeitspanne wenn man 2 (Datum/)Zeitwerte von einander abzieht.
16 Uhr - 8 Uhr ergibt eine Zeitspanne von 8 Std. Nach Deiner Interpretation würde es ja einen Mittelwert also 12 Uhr ergeben. Aber auch dann wäre die Frage was dann welches Uhrzeit/Datum dann 5 * 12 Uhr ( wenn alle Werte einer Woche addiert werden) ergeben würde.

DeddyH 8. Jun 2015 17:41

AW: Konvertierungsfehler bei Funktion
 
Müsste bei
Zitat:

Delphi-Quellcode:
sum (feld1 - feld1)

nicht sowieso immer 0 herauskommen?

mkinzler 8. Jun 2015 17:43

AW: Konvertierungsfehler bei Funktion
 
Zitat:

Zitat von DeddyH (Beitrag 1304576)
Müsste bei
Zitat:

Delphi-Quellcode:
sum (feld1 - feld1)

nicht sowieso immer 0 herauskommen?

Ich gehe mal davon aus, dass dies ein Tippfehler war.

khh 8. Jun 2015 17:57

AW: Konvertierungsfehler bei Funktion
 
ja, war ein Tippfehler,

das mit der Zeitspanne leuchtet mir ein.
Wenn ich die Abfrage direkt in der Datenbank absetzte bekomme ich einen Dezimalwert.

Heißt das ich muss als Datentyp einen Gleitkommatypen nehmen ?

mkinzler 8. Jun 2015 18:03

AW: Konvertierungsfehler bei Funktion
 
Ein TDateTime ist ja ein Double vor dem Komma steht das Datum, dahinter der Zeitanteil.
Das Problem dütfte die Interptretation des Wertes sein. Zeitspannen würde ich in einem Integer speichern ( Zeit in Millisekunden)

Dejan Vu 9. Jun 2015 07:01

AW: Konvertierungsfehler bei Funktion
 
Zitat:

Zitat von mkinzler (Beitrag 1304579)
Ein TDateTime ist ja ein Double vor dem Komma steht das Datum, dahinter der Zeitanteil.

Vor dem Komma steht nicht das Datum, sondern die Anzahl der Tage seid dem 30.12.1899. Und nach dem Komma steht keine Uhrzeit, sondern die seit Mitternacht vergangene Zeit als Bruchteil eines Tages.

Ich würde den Wert in Delphi zunächst an einen Double zuweisen und den dann so formatieren, das man etwas damit anfangen kann. Die Einheit des Dezimalwertes wäre demnach 'Tage'. So würde der Wert '1.25' der Zeitspanne 'Ein Tag und 6 Stunden entsprechen'.

khh 9. Jun 2015 07:44

AW: Konvertierungsfehler bei Funktion
 
ich danke euch recht herzlich


Alle Zeitangaben in WEZ +1. Es ist jetzt 02:18 Uhr.
Seite 1 von 3  1 23      

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