![]() |
Datenbank: MSSQL • Version: 2008 • Zugriff über: ADO
ADO Verlorene Verbindung wieder finden
Ich habe folgende Problemstellung:
AdoConnection -> AdoDataset alles besten. Nun bricht die Netzwerkverbindung ab (z.B. W-Lan)! Dataset bleiben offen, wenn ein Dataset z.B. eine Änderung an den Server senden will bekommt man "Fehler beim Verbinden" beim ADO Dataset, ok ist ja richtig (das DataSet wird Active False "ohne mein zutun") Nun steht die Netzwerkverbindung wieder AdoConnection ist noch Connected und alle anderen Verbunden DataSet sind auch noch Active (bis auf die Eine)! Nun will ich das DataSet wieder öffnen, dies wird weiterhin verweigert mit "Fehler beim Verbinden". Lösung z.Z. AdoConnection auf Connected=False setzen, ConnectionsString leeren, neu Befüllen und neu Verbinden, dann geht wieder alles. Das ist leider schlecht da viele DataSets offen sind und ich eigentlich dem AdoConnection sagen will, das er sich erneut verbinden soll, ohne die anderen DataSet zu schließen. Kennt jemand eine Lösung ? |
AW: ADO Verlorene Verbindung wieder finden
Die Connection kennt alle DataSets, die über diese verbunden sind.
![]() Da könntest du jetzt vor dem Schliessen der Verbindung alle aktiven DataSets merken, dann die Verbindung schliessen, wieder aufbauen und dann alle gemerkten DataSets wieder auf aktiv setzen. Generell würde ich aber die normalen ADO DataSets gegen ClientDataSets tauschen. |
AW: ADO Verlorene Verbindung wieder finden
Zitat:
|
AW: ADO Verlorene Verbindung wieder finden
Zitat:
Zitat:
Zitat:
In meinen Datenbank-Anwendungen gibt es immer eine
Delphi-Quellcode:
; und eine
Function TDatMod.Verbinden_Datenbank : Boolean
Delphi-Quellcode:
. Liefert die erste False zurück, lese ich das Property Fehlertext aus meinem Datenmodul aus und beende das Programm mit dieser Fehlermeldung. Dasselbe dann für die zweite Funktion. Zudem kann ich so erstens steuern, in welcher Reihenfolge meine Datasets oder Queries aktiviert werden sollen, und zweitens, welche Queries gleich geöffnet werden und welche erst bei Bedarf. In bestimmten Fällen benötige ich auch mal eine
Function TDatMod.Verbinden_Queries : Boolean;
Delphi-Quellcode:
oder
Procedure TDatMod.Schliessen_Queries;
Delphi-Quellcode:
All das habe ich in einem Default-Datenmodul bereits vorbereitet, und weil ich die DB-Connection immer ConMain nenne und ich immer eine Benutzer-Tabelle für benutzerdefinierte Einstellungen habe, existiert auch immer schon ein Qset_Benutzer, so daß ich beide Funktionen schon mal drin habe.
Procedure TDatMod.Disable_DataSources;
|
AW: ADO Verlorene Verbindung wieder finden
Zitat:
Zitat:
Wir reden hier nicht von emba Qualität ...... Nun scheint sich ein Hardwareproblem herauszustellen, heute wieder ein Crash nach 5 Stunden Dauereinsatz, hier haben sich meine SQL Anweisungen "von alleine" verändert, die in den Komponenten hinterlegt sind (mitten im SQL Statement sind einzelne Buchstaben verändert). Ich gehe nun von einem Hardwareproblem aus und tausche diese aus. Trotzdem währe ich an einer Lösung zum Verbindungsproblem interessiert, jeder der z.B. per WLan sonst Mobil arbeitet ist davon betroffen ....... |
AW: ADO Verlorene Verbindung wieder finden
Zitat:
Welchen Grund gibt es alle Datasets immer offen zu haben? Wir haben auch mit DBs zu tun und unsere App ist nach einem Reconnect (wenn der Anwender nicht gerade sein System so aufgesetzt hat das er auf oberster Einstiegsebene Tausende Einträge hat) nach 1-2 Sekunden wieder einsatzbereit. Zitat:
Zitat:
Evtl. wäre eine Browserlösung oder RemoteDesktop/Citrix-Lösung besser. Oder eine Überarbeitung des DB-Schnittstelle das diese Daten selbst in Klassen hält und nur noch bei bedarf (Update/Speichern/...) nur kurzzeitig Verbindung mit der DB aufnimmt. |
AW: ADO Verlorene Verbindung wieder finden
Ich möchte keine Diskussion wer wie alles viel schöner programmiert, das macht keinen Sinn .....
Ihr habe das Problem nicht verstanden: DataSet gehen auf und zu .... Wenn nun einmal in x Stunden zu einem Problem kommt (warum auch immer) dann verweigert ADO eine Abfrage obwohl diese wieder möglich ist ohne die Connection zu schließen und wieder zu öffnen. Hier fragt ich nach einer Idee um der ADO zusagen : "versuche es doch einfach nochmals und ignoriere dein gespeichertes Ergebnis"! |
AW: ADO Verlorene Verbindung wieder finden
Zitat:
Das mit dem ConnectionString kann ich hier nicht nachvollziehen. Kannst du einmal überprüfen, wie der ConnectionString aussieht, bevor du ihn neu zuweist? Ich kann mir nämlich nicht wirklich vorstellen, daß der ConnectionString plötzlich zerschossen sein soll. Ein Property-Wert ändert sich nicht einfach von alleine. Ich kann hier jede AdoDB-Connection schließen und öffnen, ohne den ConnectionString neu zuzuweisen, ob jetzt mit MS-Access oder MSSQL. Falls der ConnectionString dennoch zerstört sein sollte, wie du unter von deinen SQL-Anweisungen schreibst, dann hast du vermutlich defekte Ram-Module. Zitat:
Zitat:
Zitat:
Zitat:
Weiterhin behauptest du, ADO verweigere eine Abfrage, obwohl diese wieder möglich ist, ohne die Connection zu schließen und wieder zu öffnen. Verstehe ich das richtig, daß du damit die Ansicht vertrittst, daß nach einem Abbruch der Verbindung via WLan die Ado-Connection weiterhin aktiv wäre? Sei dir versichert: Genau so ist es nicht. Auch wenn die entsprechenden Properties deiner Komponenten weiterhin den Status True anzeigen (connected, active), ist die Verbindung inaktiv, wenn die WLan-Verbindung abreißt. Datenbanken vergeben Transaktions-Handles, z.B. beim Herstellen einer Verbindung oder beim Ausführen eines Select-Befehls. Diese Handles sind nach einem Abriß der WLan-Verbindung nicht mehr gültig, weshalb du nicht nur die Connection, sondern auch die Datasets erst schließen mußt, bevor du sie wieder öffnen kannst. So, jetzt klinke ich mich hier aus, bevor ich noch einen irreparablen Hirnschaden erleide :lol: |
AW: ADO Verlorene Verbindung wieder finden
@Perlsau: nehme nicht alles immer persönlich
Nochmals zum Verständnis, mein Problem: 1. einmal kurz Verbindung gestört, dann wird jegliche weitere Verbindung mit dem gleichen ConnectString verweigert!!!!!!! Lösung hier bei der ADO Connection: 2. Connected auf False setzen (Trennen) 3. ConnectString Leeren 4. ConnectString wieder auf ursprung setzen 5. Connected auf True setzt nun geht wieder alles. Schritte 2-5 möchte ich nicht, das ist meine Frage/ mein Problem! Im Programm nach einem Hänger muss es genau an der Stelle weitergehen wo es gehangen hat! Durch die Vielzahl der Möglichkeiten, was der user gerade treibt xxx DataSet auf (MDI-Fenstern) besteht keine Möglichkeit genau das wieder zur Ansicht zu bringen was gerade in der Bearbeitung ist. |
AW: ADO Verlorene Verbindung wieder finden
Wenn jetzt die Verbindung erst nach löschen und wieder setzen des Connectionstrings funktioniert würde das m.E. darauf hin deuten das in diesem Fehlerfall die dbGo-Implmentierung (Der VCL-Teil muss nach invervention so genannt werden) nicht mehr synchron mit den ADO/OLEDB-Status. Oder alternativ (was ich nicht glaube) ist hier noch ein ConnectionPool aktiv der dafür sorgt das eigentlich kaputte Connnections weiter verwendet werden.
Wenn du deine MDI-Formuarle wieder genau an die Stelle bringen willst musst du den Zustand sichern (Bookmark auslesen und nach Reconnect wieder setzen). Falls das nicht klappt den Primärschlüsselwert des aktuell markierten Datensatzes lesen und wieder setzen. |
AW: ADO Verlorene Verbindung wieder finden
Wenn eine ADO-Verbindung kaputt ist, ist sie kaputt.
Die Schritte 2 und 5 wirst zu auf jeden Fall benötigen. Eine Reanimation einer gestörten Verbindung, mit Fortsetzung im Zustand vor der Störung, ist nicht möglich. DataSets benötigen eine dauerhaft, ungestörte Verbindung. Nach einem Verbindungsverlust ist eine Reanimation und/oder ungestörte Fortführung im aktuellen Zustand nicht möglich. Bei einem Verbindungsverlust bleibt Dir nichts anderes übrig, als Dir für jeden Dataset die aktuelle Position des Datensatzzeigers... zu merken und nach dem Schließen aller DataSets beim Öffnen an diese Positionen zurückzukehren. Alternative: Alle Daten im Client vorhalten und nur Änderungen bei Bedarf an die Datenbank weitergeben bzw. von dort holen. |
AW: ADO Verlorene Verbindung wieder finden
Hmmm. Du arbeitest also mit Datasets. Nun gut. Nimm halt ClientDataSets (wurde schon erwähnt). Bei einem Refresh geht das über eine zentrale Routine, die dann eben das Reconnect-Gedöns implementiert.
Jetzt kann man sich natürlich hinstellen und sagen: "Ich will aber, das das ohne Umschreiben trotzdem funktioniert". Klar. Kann man. Bringt nur nix. :lol: |
AW: ADO Verlorene Verbindung wieder finden
Zitat:
PS: ClientDataSet will ich nicht da es hier nicht um eine Neuentwicklung geht, sondern um ein bestehendes Produkt was super läuft. Ich will ja nur die Netzwerkprobleme beim Kunden umschiffen, auf die ich keinen Einfluss habe. Wenn das Prg 2-3 sec hängt und dann weiter läuft ist alles save. Nur wenn man es erst per Taskmanager Killen muss, weil ein DataSet nach dem andern wegfliegt ist das nicht gut. |
AW: ADO Verlorene Verbindung wieder finden
Ah, verstanden. Gibt's keinen Event, in den man sich einklinken kann (zur Not mit TTimer), um dann irgendwie von Hinten durch die Brust ins Auge ein Reconnect durchzuführen?
|
AW: ADO Verlorene Verbindung wieder finden
Zitat:
|
AW: ADO Verlorene Verbindung wieder finden
So für die die es interessiert und irgendwann diesen Beitrag bei Google finden:
Lösung ist ganz einfach und auch via VPN Verbindung getestet: 2. Connection drauf, diese muss Connected=False sein Wenn es zum Netzproblem kommt und das Netz wieder da ist und es kommt trotzdem "Fehler beim Verbinden", dann der 2. Connection Connected auf False und ConnectString der ersten Übergeben Connected auf True setzen, wenn die Verbindung steht, so kann bei einem geöffneten und sogar editierten ADODataset die Connection geändert werden. Diese also auf die 2'te setzen, danach gehen auch alle Updates und inserts automatisch durch ..... Danke fürs helfen :thumb: |
AW: ADO Verlorene Verbindung wieder finden
Zitat:
Übrigens: Dein Schlips schleift auf dem Boden. |
AW: ADO Verlorene Verbindung wieder finden
Letztlich muss er erst einmal schauen, ob er ein Hardware-Problem hat. Wenn das, so gut es geht, ausgeschlossen ist kann er sich an dann eventuell noch vorhandene Software-Probleme machen.
Gibt es bei der ADO-Connection (habe ich schon ewig nicht mehr benutzt) kein Event wie "OnConnectionLost" (UniDAC), dass man dort auf das Verlieren einer Connection reagieren kann ? Wenn nicht müsste man wirklich in einem bestimmten Intervall die Verbindung abfragen und entsprechend reagieren. |
AW: ADO Verlorene Verbindung wieder finden
Zitat:
-Laptop klappt man zu und will genau dort weitermachen, wo man war -3'tes Beispiel Technikerdepp zieht das falsche Netzkabel im laufenden Betrieb und steckt es schnell wieder rein: 20 Kunden stehen an der Kasse: wer ist schuld : die Software -4'tens auf der CeBit macht man was mit W-LAN nicht weit von unserem Stand ist Samsung, die pusten das beste W_Lan in die Störung .... Es ging hier nicht um Glaubens fragen was alles besser ist oder wer hier besser und schöner ist und das jeder alles besser weis, sondern um eine zielführende Lösung, aber so ist das in Foren! |
AW: ADO Verlorene Verbindung wieder finden
Nun ja, das Grundproblem ist ja, dass dieses ADO Geraffel dafür einfach nicht ausgelegt ist. Andere Komponenten machen es da eben besser und man kann in einem Event diese Verbindung wieder neu aufbauen.
Um diesem ADO nun so etwas beizubringen muss man dieses - abenteuerlich anmutende - Tauschen der Verbindung vornehmen. Die andere Alternative wären die ClientDataSets gewesen (und erheblich mehr Aufwand beim Umsetzen). Bei einer "muss jetzt schnell fertig werden" Situation würde ich auch die erste Variante wählen ;) |
Alle Zeitangaben in WEZ +1. Es ist jetzt 05:04 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