![]() |
Datenbank: Firebird • Version: 2.5 • Zugriff über: AnyDAC 8.05 (FireDAC)
AnyDAC (FireDAC) - Exception beim schließen einer TADConnection
Hallo zusammen,
wir sind gerade dabei unsere Delphi 7 Anwendung von der BDE Komponente auf die AnyDAC 8.0.5 (FireDAC) Komponente umzustellen... Während der Umstellungsphase verwenden wir in unserer Anwendung beide Komponenten. Das heißt für die BDE Datenbankverbindung verwenden wir eine TDatabase und für die AnyDAC (FireDAC) Datenbankverbindung verwenden wird die TADConnection. Im Event OnCloseQuery der Hauptform werden die Datenbankverbindungen geschlossen:
Code:
Beim schließen der AnyDAC (FireDAC) Datenbankverbindung erhalten wir die folgende Exception:
procedure TfrmMain.FormCloseQuery(Sender: TObject; var CanClose: Boolean);
begin [...] try BDEConnection.Connected := False; except on e:exception do MessageDlg('BDEConnection' + #13#10 + e.message, mtError, [mbOK], 0); end; //-------------------------------------------------------------------- try dacConnection.Connected := False; except on e:exception do MessageDlg('dacConnection' + #13#10 + e.message, mtError, [mbOK], 0); end; [...] end; Zitat:
Hat jemand schon mal diesen Fehler? Oder eine Idee woher der Fehler kommen könnte? Edit: Die Exception erhalten wir nicht immer! Bisher konnten ich leider nicht nachvollziehen wann der Fehler auftritt! |
AW: AnyDAC (FireDAC) - Exception beim schließen einer TADConnection
(Ich weiß jetzt nicht, ob es das schon bei AnyDAC im Ggs zu FireDAC gab)
Bei FireDAC kann man über die FDConnection die Property "DataSetCount" auslesen.... ist die größer "0", dann gibt's noch Verbindungen. Mittels <FDConnection>.DataSets[0.....n-1] kann man diese auch auslesen..... |
AW: AnyDAC (FireDAC) - Exception beim schließen einer TADConnection
Was passiert wenn du die BDE Connection nicht zumachst dasselbe oder du die zwei Statements umgekehrt anordnest?
Entlädt die BDE beim Connection Close die Client Library? Der Fehler kam mir bestenfalls in multi-threaded Szenarien unter oder wenn es mit der Client Library was hat (aber an letzteres glaube ich so mal nicht). Zitat:
|
AW: AnyDAC (FireDAC) - Exception beim schließen einer TADConnection
Vielen Dank für die Antworten ...
@MEissing Die AnyDAC hat bereits die Property DataSetCount. Ich werde beim Schließen der Datenbankverbindungen jetzt eine Protokollierung einbauen, die über den DataSetCount prüft, ob noch Verbindungen offen sind... @MichaelT Bei dieser Exception habe ich leider das Problem, dass ich bisher keine Konstellation hinbekommen habe, in der der Fehler zuverlässig auftritt ... Ich werde daher mal die Reihenfolge vom Schließen der Datenbankverbindungen, wie von Dir vorgeschlagen, umkehren... D. h. zuerst die AnyDac (FireDAC) Datenbankverbindungen schließen und dann die BDE Datenbankverbindungen ... Könnte es auch sein das der ADManager Probleme macht? Würde es eventuell mein Problem lösen, wenn ich vor dem Schließen der AnyDAC (FireDAC) Datenbankverbindungen den ADManager deaktiviere:
Delphi-Quellcode:
procedure TfrmMain.FormCloseQuery(Sender: TObject; var CanClose: Boolean);
begin [...] ADManager.Active := False; //-------------------------------------------------------------------- try dacConnection.Connected := False; except on e:exception do MessageDlg('dacConnection' + #13#10 + e.message, mtError, [mbOK], 0); end; //-------------------------------------------------------------------- try BDEConnection.Connected := False; except on e:exception do MessageDlg('BDEConnection' + #13#10 + e.message, mtError, [mbOK], 0); end; [...] end; |
AW: AnyDAC (FireDAC) - Exception beim schließen einer TADConnection
Einfach probieren und rückmelden. Es wäre interessant ob die Client Library überhaupt entladen wird.
Dann müsste die BDE fliegen meiner Vermutung nach. Ob das überhaupt parallel so friktionsfrei geht, kann ich mich nicht mehr erinnern. Ich habe BDE nie benutzt. Die Support Anfragen aus Zeiten von AnyDAC sind Jahre her. Ich kann mich erinnern, dass es mal was gab in die Richtung, aber nicht mehr mit welcher Version. Die Interfaces auf der in der Meldung verwiesen wird sind jene auf mehrere Connections im Fall bspw. von Multithreading gegenüber einem Oracle Session Pool werden gehalten. Die dürften dich im Normalfall gar nicht berühren. Weswegen eher der Verdacht nahe liegt, dass es irgendetwas mit der An- resp. Abwesenheit der Client DLL zu tun hat. Zitat:
|
AW: AnyDAC (FireDAC) - Exception beim schließen einer TADConnection
Zitat:
Noch eine Nachfrage zu dem Thema... Wenn die BDE die Client Library entlädt, dann müsste ich doch immer die Exception bekommen, oder seh ich das falsch? |
AW: AnyDAC (FireDAC) - Exception beim schließen einer TADConnection
Ja. Du bekommst die Exception nicht immer?
Zitat:
|
AW: AnyDAC (FireDAC) - Exception beim schließen einer TADConnection
Zitat:
|
AW: AnyDAC (FireDAC) - Exception beim schließen einer TADConnection
Am schnellsten geht es vermutlich wenn du dich in die
Delphi-Quellcode:
in der FireDAC.Phys reinhängst.
TFDPhysManager.InternalClose(ATerminate, AWaitForClose: Boolean);
Delphi-Quellcode:
er_FD_AccShutdownTO Dabei handelt es sich um die im Beitrag zitierte Fehlerkonstante die nur dort wird abgesetzt.
finally
iStartTime := TThread.GetTickCount(); while not lTimeOut and (FDriverList.Count > 0) do begin lTimeOut := FDTimeout(iStartTime, C_FD_PhysManagerShutdownTimeout); CleanupDrivers; Sleep(1); end; if FDriverList.Count = 0 then if FState = dmsTerminating then lFree := True else if FState = dmsStoping then CleanupManager; if lTimeOut then FDException(nil, [S_FD_LPhys], er_FD_AccShutdownTO, []); if lFree then FDFree(Self); end; Der Fehler tritt im Finally Block auf. Ich schätze mal das Problem tritt im Umfeld der CleanUpDrivers auf. Wäre nur meine Vermutung. |
AW: AnyDAC (FireDAC) - Exception beim schließen einer TADConnection
Hallo,
die BDE entlädt die Dll nicht, das macht Windows. Und erst, wenn alle Programme sie per FreeLibrary freigeben haben. Denke ich mal vorsichtig. Warum Disconnectest Du dich überhaupt? Das macht doch die TAdConnection selber. |
Alle Zeitangaben in WEZ +1. Es ist jetzt 15:45 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