AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Access -> IB Problem
Thema durchsuchen
Ansicht
Themen-Optionen

Access -> IB Problem

Ein Thema von DirkG · begonnen am 6. Nov 2007 · letzter Beitrag vom 6. Nov 2007
Antwort Antwort
Benutzerbild von DirkG
DirkG

Registriert seit: 29. Sep 2003
Ort: Schwerin
67 Beiträge
 
Delphi 5 Enterprise
 
#1

Access -> IB Problem

  Alt 6. Nov 2007, 13:15
Datenbank: Interbase 6 • Zugriff über: IB Kompo
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:
// ----------------------------------------------------------------------------
// 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;
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.

Hat jemand einen Ansatzpunkt, wo ich den Fehler finden könnte.
Human are Human to make mistakes.
  Mit Zitat antworten Zitat
marabu

Registriert seit: 6. Apr 2005
10.109 Beiträge
 
#2

Re: Access -> IB Problem

  Alt 6. Nov 2007, 13:58
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: klick

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
  Mit Zitat antworten Zitat
Benutzerbild von DirkG
DirkG

Registriert seit: 29. Sep 2003
Ort: Schwerin
67 Beiträge
 
Delphi 5 Enterprise
 
#3

Re: Access -> IB Problem

  Alt 6. Nov 2007, 15:18
@marabu
Zitat:
Der einzige Treffer, den ich nicht sofort vergessen will, ist der hier: klick
Ich habe das mal versucht und auch bei mir läuft es jetzt durch. Trotzdem kann das was nicht stimmen. Wenn der Pfad in den Optionen steht, bekomme ich den Fehler immer mit der Meldung

... 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;
Human are Human to make mistakes.
  Mit Zitat antworten Zitat
hoika

Registriert seit: 5. Jul 2006
Ort: Magdeburg
8.275 Beiträge
 
Delphi 10.4 Sydney
 
#4

Re: Access -> IB Problem

  Alt 6. Nov 2007, 21:10
Hallo,

if (RecordCount <> 0) then ersetz das mal durch

if not EOF Ausserdem würde ich mal statt .Value durch AsString nehmen


Heiko
Heiko
  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 05: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