AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Sprachen und Entwicklungsumgebungen Sonstige Fragen zu Delphi Delphi Dazimaltrennzeichen verschwindet bei Auslesen aus Datenbank
Thema durchsuchen
Ansicht
Themen-Optionen

Dazimaltrennzeichen verschwindet bei Auslesen aus Datenbank

Ein Thema von ili · begonnen am 6. Apr 2011 · letzter Beitrag vom 6. Apr 2011
Antwort Antwort
ili

Registriert seit: 22. Mär 2011
4 Beiträge
 
#1

Dazimaltrennzeichen verschwindet bei Auslesen aus Datenbank

  Alt 6. Apr 2011, 14:38
Hallo,

ich lese für eine Datenbankanwendung (Delphi 2010 mit Oracle10 express) aus einem Feld der Datenbank einen Wert mit max. 2 Nachkommastellen aus.

In der Tabelle hat das Feld den Datentyp "Number" (mit 2 Nachkommastellen), das Komma wird aber nur angezeigt, wenn die Zahl Nachkommastellen hat.

Wenn ich diesen Wert in Delphi übernehme, verliere ich dabei das Dezimaltrennzeichen, in diesem Fall das " , ".

So gibt mir de rDirektzugriff auf die Datenbank den Wert 1,45 zurück, in Delphi erhalte ich den Wert 145

Der Datenbankzugriff ist per SQLConnection und SQLQuery umgesetzt.

mit folgendem Quellcode wird der Wert in Delphi übernommen:
--> kg_transport := SQLQuery1.fieldbyname('p_kg_t').AsString; und in eine Zelle eines StringGrids geschrieben:
--> StringGrid1.Cells[i,j]:= kg_transport ;

hat hier jemand eine Idee, was ich hier übersehen habe?
  Mit Zitat antworten Zitat
Benutzerbild von Bernhard Geyer
Bernhard Geyer

Registriert seit: 13. Aug 2002
17.195 Beiträge
 
Delphi 10.4 Sydney
 
#2

AW: Dazimaltrennzeichen verschwindet bei Auslesen aus Datenbank

  Alt 6. Apr 2011, 14:41
Was passiert wenn du den Wert als Floating-Wert ausliest (SQLQuery1.fieldbyname('p_kg_t').AsFloat)?
Windows Vista - Eine neue Erfahrung in Fehlern.
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.619 Beiträge
 
Delphi 12 Athens
 
#3

AW: Dazimaltrennzeichen verschwindet bei Auslesen aus Datenbank

  Alt 6. Apr 2011, 14:44
Wie sieht es so aus?
kg_transport := Format('%.2f',[SQLQuery1.fieldbyname('p_kg_t').AsFloat]); [edit] Wo war der rote Kasten? [/edit]
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
ili

Registriert seit: 22. Mär 2011
4 Beiträge
 
#4

AW: Dazimaltrennzeichen verschwindet bei Auslesen aus Datenbank

  Alt 6. Apr 2011, 15:04
leider genauso
Es sollte lt. Datenbank der Wert 1,45 stehen

kg_transport := Format('%.2f',[SQLQuery1.fieldbyname('p_kg_t').AsFloat]);
ergibt 145,00 , es werden also nur die Nachkommastellen angehängt.
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.619 Beiträge
 
Delphi 12 Athens
 
#5

AW: Dazimaltrennzeichen verschwindet bei Auslesen aus Datenbank

  Alt 6. Apr 2011, 15:11
Wie greifst Du denn auf die DB zu? ADO, ZEOS, ...? Vielleicht kommen die verwendeten Komponenten nicht mit dem Datentyp zurecht.
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
alfold

Registriert seit: 29. Jun 2010
Ort: Neustrelitz
393 Beiträge
 
Delphi 7 Enterprise
 
#6

AW: Dazimaltrennzeichen verschwindet bei Auslesen aus Datenbank

  Alt 6. Apr 2011, 15:18
mit folgendem Quellcode wird der Wert in Delphi übernommen:
--> kg_transport := SQLQuery1.fieldbyname('p_kg_t').AsString; und in eine Zelle eines StringGrids geschrieben:
--> StringGrid1.Cells[i,j]:= kg_transport ;
mal ne blöde Frage, bleibt ein String nicht ein String?
hast Du mal geschaut was in kg_transport drin steht?

alfold
  Mit Zitat antworten Zitat
ili

Registriert seit: 22. Mär 2011
4 Beiträge
 
#7

AW: Dazimaltrennzeichen verschwindet bei Auslesen aus Datenbank

  Alt 6. Apr 2011, 15:28
@ DeddyH
ich greife auf die DB mit den folgenden Komponenten zu:

TSQLCONNECTION (aus Tool-Palette dbexpress) für die Connection
TSQLQUERY(aus Tool-Palette dbexpress) für den SQL- Befehl

@alfold
auch wenn ich mir den Wert als Float ausgeben lasse
kg_trans := SQLQuery1.fieldbyname('p_kg_t').AsFloat; und den Wert in ein Textfeld ausgebe, verliere ich das Komma.
  Mit Zitat antworten Zitat
ili

Registriert seit: 22. Mär 2011
4 Beiträge
 
#8

AW: Dazimaltrennzeichen verschwindet bei Auslesen aus Datenbank

  Alt 6. Apr 2011, 15:41
ich habs herausgefunden:
in den Eingenschaften der SQLConnection gibt es einen Punkt "Decimal Separator". Der ist per default gesetzt, anscheinend habe ich den aber gelöscht.

Nach Eintrag eines Kommas als Dezimaltrenner kommen die richtigen Werte heraus.

Vielen Dank übrigens für die schnelle Hile
  Mit Zitat antworten Zitat
Antwort Antwort


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 04:44 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