![]() |
Datenbank: Interbase 6 • Zugriff über: IB Kompo
Access -> IB Problem
Hallo DP'ler,
ich bin wahrscheinlich nur betriebsblind, aber ich komme nicht weiter. Nach der Umstellung einer Accessdatenbank auf Interbase habe ich im Datenmodul folgenden Code um die ID eines Datensatzes festzustellen:
Delphi-Quellcode:
Bei der Ausführung erhalte ich die Meldung "Fehler bei der Bereichsprüfung". Ich konnte aber den Code in der IB-Console ausführen und erhielt auch das gewünschte Ergebnis.
// ----------------------------------------------------------------------------
// function GetPK(DS: TDSTitle): integer; // ---------------------------------------------------------------------------- // Function..: Determine ID of the handover parameters specified data rate // Parameter.: [DS] == actual dataset // Accessible: public function TdmTitles.GetPK(DS: TDSTitle): integer; begin //-- default return --------------------------------------------------------- Result:= -1; //if not OpenDB then exit; with dbMain do begin if Connected then Close; DefaultTransaction:= trMain; AllowStreamedConnected:= false; IdleTimer:= 0; SQLDialect:= 3; DatabaseName:= '192.168.20.208:C:\Eigene Dateien\titles.ib'; LoginPrompt := false; Params.Text := 'user_name=DIRK' + #13#10 + 'password=macabi' + #13#10 + 'lc_ctype=ISO8859_1'; end; with trMain do begin DefaultDatabase:= dbMain; Params.Add('write'); Params.Add('consistency'); end; with qrMain do begin Database:= dbMain; Transaction:= trMain; CachedUpdates:= false; end; with qrMain do begin //-- query prepare -------------------------------------------------------- SQL.Clear; SQL.Add('select * from MYTITLES where TITNAME = :TIT'); //-- query param prepare -------------------------------------------------- ParamByName('TIT').Value:= DS.Title; //-- query open ----------------------------------------------------------- try Open; if (RecordCount <> 0) then Result:= Fields.FieldByName('ID').AsInteger; Close; except on EDbengineError do raise; on EDatabaseError do abort; end; {try} end; {with} end; Hat jemand einen Ansatzpunkt, wo ich den Fehler finden könnte. |
Re: Access -> IB Problem
Hallo Dirk,
da ich den Fehler nicht aus eigener Erfahrung kenne, habe ich ein wenig gesucht. Der einzige Treffer, den ich nicht sofort vergessen will, ist der hier: ![]() Aber auch das gefällt mir nicht so recht. Kannst du die genaue Zeile im Quelltext benennen, bei welcher der Laufzeitfehler auftritt? Grüße vom marabu |
Re: Access -> IB Problem
@marabu
Zitat:
... eine Exeption der Klasse ERangeError aufgetreten. Meldung "Fehler bei Bereichsprüfung" ... und er tritt tritt beim ausführen der OPEN Anweisung der Query auf. Beim Debuggen lande ich dann in der -> IBCustomDataSet.pas -> procedure TIBCustomDataSet.FetchCurrentRecordToBuffer(Qry: TIBSQL; RecordNumber: Integer; Buffer: PChar); -> Line 1363; |
Re: Access -> IB Problem
Hallo,
Delphi-Quellcode:
ersetz das mal durch
if (RecordCount <> 0) then
Delphi-Quellcode:
Ausserdem würde ich mal statt .Value durch AsString nehmen
if not EOF
Heiko |
Alle Zeitangaben in WEZ +1. Es ist jetzt 09: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