Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Delphi MySQL Verbindung (https://www.delphipraxis.net/108411-mysql-verbindung.html)

Jonelmeier 13. Feb 2008 07:01

Datenbank: MySQL • Zugriff über: Ohne Komonenten / libmysql.dll / Übersetzte C-Header

MySQL Verbindung
 
Hallo!

Ich verwende in einem meiner Programme eine MySQL Verbindung, um Datensätze aus einer Datenbank auszulesen, zu ändern und zu löschen.
Bis jetzt habe ich zu Programmstart eine Verbindung aufgebaut und diese zur gesamten Laufzeit verwendet, also erst beim beenden des Programms wird sie geschlossen.
Jetzt mein Frage dazu: Ist das gut gelöst so? Oder sollte ich lieber bei jeder "Aktion" eine neue Verbindung aufbauen und diese am Ende der Aktion wieder schließen?

Achso, ich benutze keine Komponente dafür sondern die Übersetzten C-Header der libmysql.dll und eben diese DLL...

Wäre dankbar für 'nen Tip!

Jonas aus Hamburg

TUX_der_Pinguin 13. Feb 2008 07:12

Re: MySQL Verbindung
 
Also ich mache das immer ähnnlich beim Programm start wird die Verbindung aufgebaut, falls dieses nicht klappt kann das Programm
sich beenden, und beim beenden wird die Verbindung geschlossen. So hat man für die ganze Zeit nur eine Verbindung offen und
kann dinge wie "Last_Insert_ID()" benutzen. Desweiteren schätze ich das man damit Traffic und Rescourcen spart wenn man nicht
bei jeder Abfrage eine neue Verbindung aufbaut und diese anschließend wieder beendet. Meiner Meinung nach ist das also gut gelöst.

Luckie 13. Feb 2008 07:44

Re: MySQL Verbindung
 
Das bedeutet aber auch, dass die Datenbank die ganze Laufzeit des Programmes geöffnet ist. Und ob das so gut ist, da bin ich mir nicht so sicher.

TUX_der_Pinguin 13. Feb 2008 08:53

Re: MySQL Verbindung
 
Wenn es sich um eine Datenbank handelt die auf einem Server läuft, wieso nicht?

Luckie 13. Feb 2008 08:59

Re: MySQL Verbindung
 
Gerade dann würde ich die Verbindung nicht so lange aufhalten. Denn wenn dir die Verbindung wegbricht, musst du sie wieder neu aufbauen und dann wird dein "kann dinge wie "Last_Insert_ID()" benutzen" schief gehen.

TUX_der_Pinguin 13. Feb 2008 10:26

Re: MySQL Verbindung
 
Hmm das stimmt auch wieder, dann denke ich es ist sinnvoll bestimmte Bereiche zu kapseln. Wenn man z.b. die Einstellungen
aufruft dann wird beim Auruf des Dialogs die Verbindung hergestellt und beim beenden des Dialogs die Verbindung wieder
geschlossen. So das man nicht zur ganzen Laufzeit die Verbindung aufrecht hält sondern immer nur dann wenn es nötig ist,
aber auch nicht bei jeder einzelnen Abfrage, die Verbindung aufbauen und abbauen. Da ich erst ein oder zwei kleine Projekte
mit einer Datenbank umgesetzt habe, habe ich mir bisher nicht so viel Gedanken gemacht darüber.

Jonelmeier 13. Feb 2008 12:01

Re: MySQL Verbindung
 
Danke für eure Tipps!
Werde es dann auch so lösen, das ich Abfragen möglichst gruppiere um die Verbindung nicht ständig offen haben zu müssen!

Jonas


Alle Zeitangaben in WEZ +1. Es ist jetzt 03:53 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