AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken C# Transaction + MySQL (MyISAM)
Thema durchsuchen
Ansicht
Themen-Optionen

Transaction + MySQL (MyISAM)

Ein Thema von ArmyMan · begonnen am 3. Aug 2007 · letzter Beitrag vom 3. Aug 2007
Antwort Antwort
Benutzerbild von ArmyMan
ArmyMan

Registriert seit: 25. Mai 2004
Ort: Wil Sg
193 Beiträge
 
#1

Transaction + MySQL (MyISAM)

  Alt 3. Aug 2007, 09:26
Datenbank: MySQL • Zugriff über: MySQL.Data.dll
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
ArmyMan
Reden ist Schweigen, Silber ist Gold!
Der Soldat friert nicht. Er zittert nur vor Wut, weil es so kalt ist.
  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: Transaction + MySQL (MyISAM)

  Alt 3. Aug 2007, 09:45
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.
Windows Vista - Eine neue Erfahrung in Fehlern.
  Mit Zitat antworten Zitat
Benutzerbild von ArmyMan
ArmyMan

Registriert seit: 25. Mai 2004
Ort: Wil Sg
193 Beiträge
 
#3

Re: Transaction + MySQL (MyISAM)

  Alt 3. Aug 2007, 10:31
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
ArmyMan
Reden ist Schweigen, Silber ist Gold!
Der Soldat friert nicht. Er zittert nur vor Wut, weil es so kalt ist.
  Mit Zitat antworten Zitat
Antwort Antwort


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 07:11 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