AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Umwandlung Float in Varchar

Umwandlung Float in Varchar

Ein Thema von dataspider · begonnen am 20. Apr 2010 · letzter Beitrag vom 20. Apr 2010
Antwort Antwort
Benutzerbild von dataspider
dataspider

Registriert seit: 9. Nov 2003
Ort: 04539 Groitzsch
1.350 Beiträge
 
Delphi 11 Alexandria
 
#1

Umwandlung Float in Varchar

  Alt 20. Apr 2010, 08:29
Datenbank: Firebird • Version: 2.13 • Zugriff über: IBDac
Hi,

ich muss einen Float - Wert in seine Besatndteile zerlegen.
Dafür habe ich mir eine SP geschrieben.

Leider ist das Verhalten bezüglich der Umwandlung in Firebird unterschiedlich.

Der Test mit folgendem Statement liefert das gewünschte Ergebnis:
select lpad(trunc(10077.34), 6, '0') from rdb$database Ergebnis: 010077

Das gleiche aus der SP:
SQL-Code:
create procedure TRUS_ARTIKELNUMMER (
    WERT type of WAEHRUNG)
returns (
    NUMMER type of VARCHAR6,
    ZUSATZ type of VARCHAR2)
as
begin
  nummer = lpad(trunc(:wert), 6, '0');
  zusatz = lpad(trunc((:wert - trunc(:wert)) * 100), 2, '0');
  suspend;
end
liefert dann aber:
10077.

Wie wandelt man Integer in Varchar ohne den Tausender - Punkt.

Frank
Frank Reim
  Mit Zitat antworten Zitat
soulies

Registriert seit: 9. Dez 2005
234 Beiträge
 
#2

Re: Umwandlung Float in Varchar

  Alt 20. Apr 2010, 10:21
hi,

in mysql funzt folgendes:

Format(wert,anzahl nachkommastellen) -> ergebnis als string

Bsp:
Format(210.40,0) = 210


Vllt. kannst du eine ähnliche Funktion in FB benutzen .


Soulies
  Mit Zitat antworten Zitat
Benutzerbild von dataspider
dataspider

Registriert seit: 9. Nov 2003
Ort: 04539 Groitzsch
1.350 Beiträge
 
Delphi 11 Alexandria
 
#3

Re: Umwandlung Float in Varchar

  Alt 20. Apr 2010, 11:31
Hi,

Format gibt es in Firebird nicht.
Wenn ich aber das Statement auflöse und den Umweg über eine Variable mache, dnn geht es:

SQL-Code:
create procedure TRUS_ARTIKELNUMMER (
    WERT type of WAEHRUNG)
returns (
    NUMMER type of VARCHAR6,
    ZUSATZ type of VARCHAR2)
as
declare variable TEMP INTEGER$;
begin
  temp = trunc(:wert);
  nummer = lpad(:temp, 6, '0');
  zusatz = lpad(trunc((:wert - trunc(:wert)) * 100), 2, '0');
  suspend;
end
Und der Punkt ist auch der Dezimalpunkt...

Ist zwar verwirrend, aber funktioniert so.

Danke

Frank
Frank Reim
  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 18:06 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