![]() |
Re: Fehlerbehandlung komisch
Zitat:
#$D und #$A sind ASCII-Steuerzeichen. $0D steht für Carriage Return $0A steht für Linefeed Das bedeutet also ersteinmal nur das am ende deiner SQL-Anweisung ein "Zeilenumbruch" kommt. Das sollte aber keine Probleme machen. |
Re: Fehlerbehandlung komisch
hmmm, dann bin ich mit meinem latein jetzt wirklich am ende :-(
|
Re: Fehlerbehandlung komisch
Und wie wärs mit einzelanweisung?
Also oben VOR dem Fehler mit F5 einen Haltepunkt setzen und dann wenn das Programm dort angekommen ist mit F7 jede einzelne anweisung bis zum Fehler einzeln ausführen. |
Re: Fehlerbehandlung komisch
Bau es doch mal ein wenig um.
Delphi-Quellcode:
Ich glaube mich dunkel zu erinnern mit diesen Steuerzeichen auch schonmal ein Problem gehabt zu haben.
procedure TfrmChange.lbInstProgDblClick(Sender: TObject);
var vorhanden, verwendet : integer; begin IBQuery1.SQL.Clear; IBQuery1.SQL.ADD('SELECT INST_PROGR, VORH_LIZENZEN FROM T_PROGR WHERE PROGR_STRING = '); IBQuery1.SQL.ADD('QuotedStr(lbInstProg.Items[lbInstProg.ItemIndex]'); IBQuery1.Open; while not IBQuery1.Eof do begin try vorhanden := IBQuery1.FieldByName('VORH_LIZENZEN').AsInteger; verwendet := IBQuery1.FieldByName('INST_PROGR').AsInteger; lblVerwendet.Caption := 'Verwendete Lizenzen: '+IntToStr(verwendet); edLiz.Text := IntToStr(vorhanden); IBQuery1.Next; except IBQuery1.Next; end; end; end; |
Re: Fehlerbehandlung komisch
@schubi: über die einzelanweisungen und den debugger bin ich ja auf diese steuerzeichen gekommen
ich befürchte ich muss die irgendwie umwandeln oder so... |
Re: Fehlerbehandlung komisch
Zitat:
Ich sehe in deinem Code keinen Grund, den Weg uber eine Variable zu gehen und diese dann wiederum der Query zuzuweisen. Die Zuweisung zu querystring ist so über wie Ratten im Keller und verursacht nebenbei diesen hübschen Effekt, der wieder muss mit nochmehr Code(z.B. Stringreplace) ausgeputzt werden. Warum machst du es dir selbst so schwer? |
Re: Fehlerbehandlung komisch
Zitat:
aber ich werde deinen rat mal beherzigen!!! was ich aber immer noch nicht verstehen ist warum der try-except-block nicht jeden fehler abfängt sondern nur sporadisch. ich kann da keine regel dahinter erkennen...? |
Re: Fehlerbehandlung komisch
Hallo,
kann es sein, daß dein ganzes Programm wesentlich mehr macht, als diese eine Prozedur...? Ich hatte mal ein Problem, wo Exceptions immer auf dem Bildschirm aufgetaucht sind, oder eben garnicht!! Da hatte ich gerade vorher ein unfangreiches Logging-System bei Application.OnException fertiggestellt. Sonst hätte ich bei der Situation aufgegeben. Es war nicht nachvollziehbar. Was macht dein Programm vorher... Assembler? Interrupts? Timer? Kann alles zu dem von dir beschriebenen Problem führen... mfg... ...Matthias |
Re: Fehlerbehandlung komisch
Ja was macht mein Programm vorher *überleg*
Also es startet und stellt eine Verbindung zu einer Interbase-DB her. Dort liest es alle Usernamen. alle Rechnernamen, alle Betriebssysteme und alle Seriennummern aus, sund trägt diese in ComboBoxen ein. Weiterhin ist da noch eine ComboBox die die Prozessoren enthält (P4, 3, 2, ...) Da kann mann dann ne Suchabfrage über die ComboBoxes formulieren, also zB "zeig mir alle Rechner mit P4 Prozessor die noch Windows NT installiert haben". Dieses Suchergebnisse werden in einer ListBox dargestellt. Nach einem Doppelklick auf einen bestimmten Rechner geht eine neue Maske hoch die in zwei Karteireiter unterteilt ist. Auf der einen Seite werden sämtliche bekannten Hardwaredaten über den Rechner angezeigt, sowie die aktuelle IP und der angemeldete User ermittelt. Diese Daten lassen sich ändern, drucken, speichern, etc. Der andere Karteireiter zeigt die auf diesem Rechner installierten Programme, ebenfalls in einer Listbox, an. Nach einem Doppelklick auf eines der installierten Programme liest mein Tools aus der Datenbank die Anzahl der Rechner aus, die dieses Programm installiert haben, sowie die Anzahl der vorhandenen Lizenzen für dieses Programm. Genau an dieser Stelle kommt dann auch der Fehler hoch. Die SQL-Abfragen sind korrekt, das hab ich in der Konsole überprüft, also kann es daran nicht liegen! Ich bin im Debug-Mode sauber durchgestept und kann aber kein Fehler finden der die Exception an dieser Stelle auslösen könnte :-( |
Re: Fehlerbehandlung komisch
Hi,
guck ich falsch oder wurde IBQuery1 nie erzeugt??? Gruß Tyrael |
Alle Zeitangaben in WEZ +1. Es ist jetzt 07:27 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz