AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Meine SqLite-Datenbank ist korrupt. Wie bekomme ich sie wieder heile?
Thema durchsuchen
Ansicht
Themen-Optionen

Meine SqLite-Datenbank ist korrupt. Wie bekomme ich sie wieder heile?

Ein Thema von Der schöne Günther · begonnen am 15. Sep 2017 · letzter Beitrag vom 18. Sep 2017
 
Der schöne Günther

Registriert seit: 6. Mär 2013
6.201 Beiträge
 
Delphi 10 Seattle Enterprise
 
#1

Meine SqLite-Datenbank ist korrupt. Wie bekomme ich sie wieder heile?

  Alt 15. Sep 2017, 12:59
Datenbank: SQLite • Version: 3.8.7.4 • Zugriff über: FireDAC
Stromausfall, SqLite-Datenbank kaputt. Sobald man sagt myConnection.Connected := True wirft FireDAC eine ESQLiteNativeException mit
Zitat:
[FireDAC][Phys][SQLite] ERROR: database disk image is malformed
.

Er hat auch Recht, sie scheint nicht in Ordnung zu sein. Jetzt hat FireDAC hierfür ein TFDSQLiteValidate im Angebot. Es bietet Methoden wie Analyze(..) oder CheckOnly() . Hört sich genau danach an was ich brauche.

Leider funktioniert das Ding nicht, denn das TFDSQLiteValidate erstellt sich als erstes seine eigene Sqlite-Connection und sagt darauf dann open() . Und das wirft leider schon die Exception. Ich kann mich im Debugger einklemmen und im Connection-String hierfür z.B. ein ; PRAGMA integrity_check anhängen, dann gibt es keine Exception. Aber das bringt anscheinend den Ablauf durcheinander, das Tool meint dann alles sei in Ordnung was ja völliger Käse ist.


Meine Frage: Benutze ich das Ding falsch oder ist es kaputt?
  Mit Zitat antworten Zitat
 


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 21:32 Uhr.
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz