AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Sprachen und Entwicklungsumgebungen Sonstige Fragen zu Delphi Delphi Merkwürdiger Fehler bei Datenzuweisung

Merkwürdiger Fehler bei Datenzuweisung

Ein Thema von Delix · begonnen am 24. Feb 2013 · letzter Beitrag vom 25. Feb 2013
Antwort Antwort
Delix

Registriert seit: 4. Mai 2004
Ort: Lippstadt
56 Beiträge
 
#1

Merkwürdiger Fehler bei Datenzuweisung

  Alt 24. Feb 2013, 09:09
Hallo zusammen!

Ich habe ein seltsames Problem bei einem Datenimportprogramm für Firebird. Daten werden aus Textdateien in die Datenbank geschrieben. Es wird mit TIBCQuery gearbeitet: Append - Felder zuweisen - Post usw.

Bei etwas größeren Dateien kommt es regelmäßig vor, das beim Zuweisen einer Gleitkommazahl zu einem Floatfeld die Meldung "xx.xx ist kein gültiger Gleitkommawert" erscheint, obwohl xx.xx ein gültiger Wert ist. Der Error ist abgefangen und wird protokolliert, das Programm läuft weiter. Nachdem der Fehler bei einer Tabelle einmal aufgetreten ist, kommt er bei Zuweisung jeder gebrochnen Zahl bis zum Ende der Tabelle.
Das Witzige ist, wann der Fehler einsetzt ist immer unterschiedlich. Mal nach ca. 12000 Sätzen, mal nach 25000 etc. Immer mit den selben Daten neu gestartet. Wenn man Glück hat, läuft das Programm ganz ohne Fehler durch.
An den Komponenten liegt es nicht. Ich habe den selben Effekt bei Zeos und auch bei IBDAC.

Hat eventuell irgend jamand eine Idee?
  Mit Zitat antworten Zitat
Benutzerbild von Bernhard Geyer
Bernhard Geyer

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

AW: Merkwürdiger Fehler bei Datenzuweisung

  Alt 24. Feb 2013, 09:22
Arbeitest du mit parametrisierten Inserts?
Windows Vista - Eine neue Erfahrung in Fehlern.
  Mit Zitat antworten Zitat
Delix

Registriert seit: 4. Mai 2004
Ort: Lippstadt
56 Beiträge
 
#3

AW: Merkwürdiger Fehler bei Datenzuweisung

  Alt 25. Feb 2013, 12:50
Ich habe mit Zeos-Komponenten getestet, die arbeiten nicht parametriert. IBDAC arbeitet parametriert. Das Problem scheint gar nicht in den Datenbank-Controls zu liegen.

Beispiel:
Import.FieldByName('Betrag').asFloat:=StrToFloat(Value); ergibt einen Fehler

Import.FieldByName('Betrag').asString:=Value; ebenfalls.

Inzwischen habe ich mal wieder einen Programmlauf ohne Fehler durchbekommen.

Schönen Gruß
  Mit Zitat antworten Zitat
Benutzerbild von dataspider
dataspider

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

AW: Merkwürdiger Fehler bei Datenzuweisung

  Alt 25. Feb 2013, 13:01
Ich würde mir im Fehlerfall den String mal ausgeben lassen.
Da gibt es einige Fallstricke (Tausender - Trennzeichen, Dezimal - Trennzeichen, Leerzeichen, Größe).

Frank
Frank Reim
  Mit Zitat antworten Zitat
Delix

Registriert seit: 4. Mai 2004
Ort: Lippstadt
56 Beiträge
 
#5

AW: Merkwürdiger Fehler bei Datenzuweisung

  Alt 25. Feb 2013, 13:51
Hab ich natürlich als erstes gemacht. Wenn es an den Daten läge, könnte das Programm ja nicht mit den selben Daten immer an anderer Stelle abbrechen bzw. irgendwann komlett ohne Fehler durchlaufen.
  Mit Zitat antworten Zitat
Benutzerbild von Sir Rufo
Sir Rufo

Registriert seit: 5. Jan 2005
Ort: Stadthagen
9.454 Beiträge
 
Delphi 10 Seattle Enterprise
 
#6

AW: Merkwürdiger Fehler bei Datenzuweisung

  Alt 25. Feb 2013, 17:04
Wenn dein Rechner mit der deutschen Einstellung läuft, dann kann der String 0.00 nicht in einen Float umgewandelt werden. Denn das Dezimaltrennzeichen ist auf , eingestellt.

Also musst du entweder die FormatSettings für die Umwandlung anpassen Delphi-Referenz durchsuchenStrToFloat und dafür sorgen, dass alle Daten diesen Dezimaltrenner benutzen oder du wandelst mit Delphi-Referenz durchsuchenTryStrToFloat einmal mit dem , und wenn das nicht geht dann nochmal mit dem . als Dezimaltrenner.

Wie du dann darauf reagieren willst, wenn beide nicht gehen, das bleibt dir überlassen.

BTW läuft diese Übertragung in einem eigenen Thread? Dann solltest du auf jeden Fall die FormatSettings bei jedem Aufruf mitgeben.
Kaum macht man's richtig - schon funktioniert's
Zertifikat: Sir Rufo (Fingerprint: ‎ea 0a 4c 14 0d b6 3a a4 c1 c5 b9 dc 90 9d f0 e9 de 13 da 60)

Geändert von Sir Rufo (25. Feb 2013 um 17:07 Uhr)
  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:59 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