AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Aggregated Field summiert falsch

Aggregated Field summiert falsch

Ein Thema von Rainer Wolff · begonnen am 17. Feb 2012 · letzter Beitrag vom 20. Feb 2012
Antwort Antwort
Rainer Wolff

Registriert seit: 25. Okt 2005
Ort: Bretten
318 Beiträge
 
Delphi 10.4 Sydney
 
#1

Aggregated Field summiert falsch

  Alt 17. Feb 2012, 13:53
Datenbank: Firebird • Version: 2.5 • Zugriff über: dbx
Hallo,

ich versuche mich gerade an aggregated fields im Clientdataset. Wenn ich bei meinen Float-Datenbankfeldern, die als TSingleint im Dataset landen, eine Summe bilden will, bekomme ich einen Wert wie 5,68248093194E-315 zurück, obwohl normale Zahlen in den Feldern stehen. Die selbe Aufsummierung über ein Integerfeld funzt hingegen. Im Anhang habe ich einen Screenshot beigefuegt (numerototal und qtotal sind die int bzw. float-summen von numerofusion und quantite1)
Kennt jemand dieses Problem?

Gruß Rainer
Miniaturansicht angehängter Grafiken
project1-delphi-xe-unit1-%5Bbuilt%5D_2012-02-17_14-11-25.jpg  
  Mit Zitat antworten Zitat
Benutzerbild von p80286
p80286

Registriert seit: 28. Apr 2008
Ort: Stolberg (Rhl)
6.659 Beiträge
 
FreePascal / Lazarus
 
#2

AW: Aggregated Field summiert falsch

  Alt 17. Feb 2012, 14:20
hast Du mal versucht die Darstellung zu ändern?
z.B.
Code:
To_Char(mysum,'999999.99999')
(ich gehe mal davon aus, daß die Grundlage Deiner Anzeige eine Query ist)

Gruß
K-H
Programme gehorchen nicht Deinen Absichten sondern Deinen Anweisungen
R.E.D retired error detector
  Mit Zitat antworten Zitat
Rainer Wolff

Registriert seit: 25. Okt 2005
Ort: Bretten
318 Beiträge
 
Delphi 10.4 Sydney
 
#3

AW: Aggregated Field summiert falsch

  Alt 20. Feb 2012, 14:47
Ich weiss nicht, an welcher Stelle ich das to_char jetzt anbringen soll?

Min, max, count funktionieren, aber sum, avg bringen abstruse Werte
  Mit Zitat antworten Zitat
Rainer Wolff

Registriert seit: 25. Okt 2005
Ort: Bretten
318 Beiträge
 
Delphi 10.4 Sydney
 
#4

AW: Aggregated Field summiert falsch

  Alt 20. Feb 2012, 15:28
Inzwischen habe ich in der dbclient.pas folgenden Code gefunden:

Code:
function AggValueAsVariant(Agg: TAggregate; Buffer: Pointer): Variant;
var
  C: Currency;
begin
  case Agg.DataType of
    ftByte:
      Result := Byte(Buffer^);

   ....

    TFieldType.ftSingle:
      Result := Single(Buffer^);
    ftFloat:
      Result := Double(Buffer^);
    ftBCD, ftFMTBcd:
.....
An der Stelle wird der Code fuer ftFloat ausgefuehrt, obwohl mein Feld vom Typ TSingleField ist. Und sobald ich statt Sum als Aggregatfunktion Min oder Max wähle, wird mein Feldtyp ftSingle und die Aggregatfunktion stimmt.

Aber sonst bin ich im VCL-Code noch nicht durchgestiegen, wann welcher Feldtyp gewählt wird.
  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 14:05 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