Delphi-PRAXiS
Seite 1 von 2  1 2      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Delphi Muss die Verbindung zur DB immer geschlossen werden? (https://www.delphipraxis.net/70075-muss-die-verbindung-zur-db-immer-geschlossen-werden.html)

davar 24. Mai 2006 16:40

Datenbank: MySQL • Version: 4.x • Zugriff über: Zeos

Muss die Verbindung zur DB immer geschlossen werden?
 
Hallo Leute,

zwar wurde die Frage bereits hier gestellt, jedoch hätte ich gern - wenn möglich - eine detailliertere Antwort.

In meiner Software habe ich verschiedene datensensitive Komponenten eingesetzt (DBEdits, DBGrids usw.). Wenn ich nun die Verbindung beende, wird in diesen Komponenten nichts mehr angezeigt, deswegen lasse ich die Verbindung einfach offen. Nun würd ich gern wissen, inwiefern es denn dann Probleme geben kann, wenn die Software im Netzwerk mit 4-5 Clients benutzt wird.

MfG

davar

Bernhard Geyer 24. Mai 2006 19:45

Re: Muss die Verbindung zur DB immer geschlossen werden?
 
Bei MySQL - eigentlich fast keine da MySQL keine serverseitigen Curser hat und damit offene Querys für die DB keine Last darstellen da immer sofort alle Datensätze zum Client übertragen werden. Und 4-5 offene DB-Verbindungen da lacht selbst MySQL darüber.

Niko 24. Mai 2006 20:02

Re: Muss die Verbindung zur DB immer geschlossen werden?
 
Hi,

vor .net Zeiten war es in Delphi üblich die Verbindung zur Datenbank über die ganze Programmlaufzeit offen zu halten. Wenn du die Verbindung häufig wieder benötigst ist das Schließen sogar ungünstig, da der Verbindungsaufbau jedesmal Rechenzeit kostet (beim Client und beim Server). Eventuell betreiben die Zeos-Komponenten aber auch Connection-Pooling, was bedeuten würde, dass die Verbindung beim Schließen im Hintergrund noch eine Zeit lang geöffnet bleibt, um bei Bedarf wiederverwendet zu werden.

Probleme beim Zugriff mehrerer Clients, die ihre Verbindungen jeweils lange offen halten, darf es bei einem vernünftigen Datenbanksystem nicht geben, schon gar nicht mit nur 4-5 Clients. Datenbanksysteme wie MySQL sind ja darauf ausgelegt, gleichzeitige Verbindungen von mehreren hundert Clients handhaben zu können. Die Maximalzahl an gleichzeitigen Verbindungen sollte sich in der Dokumentation der Datenbank finden lassen und kann auch durchaus abhängig von der eingesetzten Lizenz sein. Wichtig ist nur darauf zu achten, dass die Clients keine Transaktionen über längere Zeit geöffnet halten, denn damit würden sie den Zugriff auf die betroffenen Sätze durch andere Clients einschränken.

davar 25. Mai 2006 09:04

Re: Muss die Verbindung zur DB immer geschlossen werden?
 
Zitat:

Zitat von Niko
Wichtig ist nur darauf zu achten, dass die Clients keine Transaktionen über längere Zeit geöffnet halten, denn damit würden sie den Zugriff auf die betroffenen Sätze durch andere Clients einschränken.

Was genau kann ich denn hier drunter verstehen? Wie bleibt denn eine Transaktion geöffnet?

mkinzler 25. Mai 2006 09:16

Re: Muss die Verbindung zur DB immer geschlossen werden?
 
Zitat:

Was genau kann ich denn hier drunter verstehen? Wie bleibt denn eine Transaktion geöffnet?
In dem man sie nicht schließt.
Bei MySQL kommt es aber auf die Storage-Engine an ob Transkationen überhaupt unterstützt werden.
Transaktioene sorgen dafür das zusammenhängende Datenmanipulationen entweder komplett durchgefüht werden oder komplett zurückgesetzt werden können. Je nach Transaktions-Isolation sind die Änderungen, dann für andere Clients erst nach einem Commit sichtbar.

davar 25. Mai 2006 09:55

Re: Muss die Verbindung zur DB immer geschlossen werden?
 
Und wie mache ich es denn am besten, wenn ich das Formular mit den datensensitiven Komponenten schließe? Auf TQuery kann ich nicht zugreifen, weil die Komponenten die Verbindung beibehalten. Die Komponenten sollen nicht ganz entfernt werden, weil das Formular immer wieder geöffnet wird, und für jedes Formular möchte ich nicht ein eigenes Query einsetzen. Wie mach ich das denn am sinnvollsten?

mkinzler 25. Mai 2006 10:08

Re: Muss die Verbindung zur DB immer geschlossen werden?
 
Welcher Isolationslevel steht in dein ZTransaction-Kompoenente?

davar 25. Mai 2006 10:17

Re: Muss die Verbindung zur DB immer geschlossen werden?
 
Zitat:

Zitat von mkinzler
Welcher Isolationslevel steht in dein ZTransaction-Kompoenente?

hmm.. da bin ich jetzt ein wenig überfordert. Ich hab sie zwar eingebunden, aber im Quellcode kein einziges Mal angesprochen. Ist das denn notwendig?

mkinzler 25. Mai 2006 19:35

Re: Muss die Verbindung zur DB immer geschlossen werden?
 
Vermutlich unterstützt deine Storage Engine sowieso kein Transaktionen. Die Standard-Isolationsstufe ist meines Wissens auch eh autocommit.

davar 25. Mai 2006 20:51

Re: Muss die Verbindung zur DB immer geschlossen werden?
 
Zitat:

Zitat von mkinzler
Vermutlich unterstützt deine Storage Engine sowieso kein Transaktionen. Die Standard-Isolationsstufe ist meines Wissens auch eh autocommit.

hmm. Was heisst das jetzt konkret für mich?


Alle Zeitangaben in WEZ +1. Es ist jetzt 00:51 Uhr.
Seite 1 von 2  1 2      

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