AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Fehler durch Verbindungsverlust abfangen
Thema durchsuchen
Ansicht
Themen-Optionen

Fehler durch Verbindungsverlust abfangen

Ein Thema von erich.wanker · begonnen am 8. Jul 2009 · letzter Beitrag vom 8. Jul 2009
Antwort Antwort
Benutzerbild von erich.wanker
erich.wanker

Registriert seit: 31. Jan 2008
Ort: im schönen Salzburger Land
454 Beiträge
 
Delphi XE4 Professional
 
#1

Fehler durch Verbindungsverlust abfangen

  Alt 8. Jul 2009, 11:09
Datenbank: Firebird • Version: 2.1.0 • Zugriff über: ZEOS
Hallo Leute,

Wenn PC1 (DatenbankServer) abgeschaltet wird, oder sagen wir mal, jemand schaltet den Switch ab - schmiert die Client-Anwendung auf PC2 ab ..

Wie kann ich das am besten abfangen und meine Anwendung sauber schließen ?


vielen Dank

Erich




P.S.:
Firebird SQL Server 2.1.0:
Auf PC1 ist Firebird Superserver und die GDB (port 3050 frei ect..)
auf PC2 ist die Anwendung, die via TCP/IP mit PC1 verbunden ist:
Erich Wanker - for life:=1971 to lebensende do begin ..
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
43.167 Beiträge
 
Delphi 12 Athens
 
#2

Re: Fehler durch Verbindungsverlust abfangen

  Alt 8. Jul 2009, 11:16
wie: Zugriffe auf die Datenbank per Try-Except absichern
Garbage Collector ... Delphianer erzeugen keinen Müll, also brauchen sie auch keinen Müllsucher.
my Delphi wish list : BugReports/FeatureRequests
  Mit Zitat antworten Zitat
Benutzerbild von erich.wanker
erich.wanker

Registriert seit: 31. Jan 2008
Ort: im schönen Salzburger Land
454 Beiträge
 
Delphi XE4 Professional
 
#3

Re: Fehler durch Verbindungsverlust abfangen

  Alt 8. Jul 2009, 12:54
Hallo Himitsu,

??? .. irgendwie steh ich auf dem Schlauch..

Wenn ich die Zeos connection via Try except absichere - hilft das nichts
Wenn ich ein Query SQL Statement via try except absichere - hilft das auch nix


TZConnection beforeDisconnect und AfterDisconnect sind ja "geplante und bewußte" Abschaltungen.. mit diesen Events kann ich also auch nix anfangen..


Wenn ich den Switch abdrehe - und in einem DBGrid den nächsten record anklicke - kommt:

Zitat:
SQL Error: Unable to complete network request to host"@1". Error writing data to the connection. Eine vorhandene verbindung wurde vom Remotehost geschlossen.
. Error Code: -902. Unsuccessful execution caused by a system error that precludes successful execution of subsequent statements The SQL: Select trallala ....

..

Erich
Erich Wanker - for life:=1971 to lebensende do begin ..
  Mit Zitat antworten Zitat
mjustin

Registriert seit: 14. Apr 2008
3.005 Beiträge
 
Delphi 2009 Professional
 
#4

Re: Fehler durch Verbindungsverlust abfangen

  Alt 8. Jul 2009, 15:24
Zitat von erich.wanker:

Wenn ich den Switch abdrehe - und in einem DBGrid den nächsten record anklicke - kommt:

Zitat:
SQL Error: Unable to complete network request to host"@1". Error writing data to the connection. Eine vorhandene verbindung wurde vom Remotehost geschlossen.
. Error Code: -902. Unsuccessful execution caused by a system error that precludes successful execution of subsequent statements The SQL: Select trallala ....

..

Erich

Das ist der Nachteil bei RAD: es geht schnell, aber es geht auch schnell wieder kaputt

Das DBGrid hat keine Eventhandler, in dem man die Exception abfangen könnte. Auf Applikationsebene oder mit madExcept könnte man es global abfangen. Dann hat man aber recht wenig Kontextinformationen, mit denen man dann die Abfrage hinter dem Grid schliessen und dann nach einer Retry-Message wieder öffnen könnte.

Mit ClientDataSet kann man in etwa so arbeiten:

Delphi-Quellcode:
Query.Close;
try
  Query.ParamByName('...').AsInteger := ...
  Query.Open;
  Connection.Close; // Verbindung darf getrennt werden, da ClientDataSet die Daten puffert
except
  on E:...Exception do
  begin
    if FragDenUser('Retry?') then
    begin
      VersuchsNocheinmal;
    end;
  end
end;
Michael Justin
habarisoft.com
  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 23:23 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