Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   C# Transaction + MySQL (MyISAM) (https://www.delphipraxis.net/97030-transaction-mysql-myisam.html)

ArmyMan 3. Aug 2007 08:26

Datenbank: MySQL • Zugriff über: MySQL.Data.dll

Transaction + MySQL (MyISAM)
 
Hi @ll

Stehe gerade vor einem KLEINEN Problem. Und zwar muss ich Daten in eine MySQL DB (MyISAM Engine) schreiben und wie ihr sicherlich alle wisst, unterstützt MyISAM keine Transactions. Dies muss aber zwingend sein. Da es ein Chaos geben würde in der DB falls nicht alle Einträge richtig geschrieben wären.
Was habe ich da noch für "gescheidte" Möglichkeiten diese Problem zu beheben?
Die DB Engine auf InnoDB ändern ist in meinem Fall leider nicht möglich.

Greetz

Bernhard Geyer 3. Aug 2007 08:45

Re: Transaction + MySQL (MyISAM)
 
Du müstest selbst eine Transaktionssystem (Logfile etc, ...) nachbauen das auch bei einem Stromausfall noch fähig ist die Daten nach Reeboot zu schreiben. Also m.E. steht das in keinem Verhältniss zum ändern der Tabelel auf InnoDB.

Auch hast du bei fehlender Transaktionsunterstützung auf DB-Seite das Problem das während du die einzelnen Datensätze schreibst schon ein andere Programm diesen inkonsistenten Zustand auslesen kann. Und das könntest du nur verhindern wenn alle Lese/Schreiboperationen über dein Programm laufen.

ArmyMan 3. Aug 2007 09:31

Re: Transaction + MySQL (MyISAM)
 
Hmm..
Das heisst also, dass es sozusagen unmöglich ist eine saubere Transaction nachzubauen?
Eine andere Möglichkeit wäre halt eben die Tabellen welche ich ändere zu speichern vor dem schreiben und bei einem Fehler diese wiederherzustellen. Was aber nichts an der inkonsistenz ändert wenn die DB während dem Prozess abstürzt z.B.

Hoffe jemand hat sonst eine Lösung oder Ansatz.

Greetz


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