AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Muss die Verbindung zur DB immer geschlossen werden?
Thema durchsuchen
Ansicht
Themen-Optionen

Muss die Verbindung zur DB immer geschlossen werden?

Ein Thema von davar · begonnen am 24. Mai 2006 · letzter Beitrag vom 25. Mai 2006
Antwort Antwort
Seite 1 von 2  1 2      
davar

Registriert seit: 4. Feb 2005
311 Beiträge
 
Turbo Delphi für Win32
 
#1

Muss die Verbindung zur DB immer geschlossen werden?

  Alt 24. Mai 2006, 17:40
Datenbank: MySQL • Version: 4.x • Zugriff über: Zeos
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
  Mit Zitat antworten Zitat
Benutzerbild von Bernhard Geyer
Bernhard Geyer

Registriert seit: 13. Aug 2002
17.195 Beiträge
 
Delphi 10.4 Sydney
 
#2

Re: Muss die Verbindung zur DB immer geschlossen werden?

  Alt 24. Mai 2006, 20:45
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.
Windows Vista - Eine neue Erfahrung in Fehlern.
  Mit Zitat antworten Zitat
Niko

Registriert seit: 23. Jun 2003
416 Beiträge
 
Delphi 2006 Professional
 
#3

Re: Muss die Verbindung zur DB immer geschlossen werden?

  Alt 24. Mai 2006, 21:02
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.
  Mit Zitat antworten Zitat
davar

Registriert seit: 4. Feb 2005
311 Beiträge
 
Turbo Delphi für Win32
 
#4

Re: Muss die Verbindung zur DB immer geschlossen werden?

  Alt 25. Mai 2006, 10:04
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?
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.858 Beiträge
 
Delphi 11 Alexandria
 
#5

Re: Muss die Verbindung zur DB immer geschlossen werden?

  Alt 25. Mai 2006, 10:16
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.
Markus Kinzler
  Mit Zitat antworten Zitat
davar

Registriert seit: 4. Feb 2005
311 Beiträge
 
Turbo Delphi für Win32
 
#6

Re: Muss die Verbindung zur DB immer geschlossen werden?

  Alt 25. Mai 2006, 10:55
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?
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.858 Beiträge
 
Delphi 11 Alexandria
 
#7

Re: Muss die Verbindung zur DB immer geschlossen werden?

  Alt 25. Mai 2006, 11:08
Welcher Isolationslevel steht in dein ZTransaction-Kompoenente?
Markus Kinzler
  Mit Zitat antworten Zitat
davar

Registriert seit: 4. Feb 2005
311 Beiträge
 
Turbo Delphi für Win32
 
#8

Re: Muss die Verbindung zur DB immer geschlossen werden?

  Alt 25. Mai 2006, 11:17
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?
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.858 Beiträge
 
Delphi 11 Alexandria
 
#9

Re: Muss die Verbindung zur DB immer geschlossen werden?

  Alt 25. Mai 2006, 20:35
Vermutlich unterstützt deine Storage Engine sowieso kein Transaktionen. Die Standard-Isolationsstufe ist meines Wissens auch eh autocommit.
Markus Kinzler
  Mit Zitat antworten Zitat
davar

Registriert seit: 4. Feb 2005
311 Beiträge
 
Turbo Delphi für Win32
 
#10

Re: Muss die Verbindung zur DB immer geschlossen werden?

  Alt 25. Mai 2006, 21:51
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?
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


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 06:04 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