![]() |
Datenbank: Advantage Database Server • Version: 9 • Zugriff über: ADS
Backup mit storedProcedure und anschließendes zippen
Hi all,
eine eigentlich simple Aufgabe: Ich will ein Backup einer Datenbank erstellen (mit einer StoredProcedure welche das DBMS bereitstellt). Anschließend soll das erstellte Backup in eine Zip-File gepackt werden (Benutzer die TZipMaster Komponente). Nun habe ich folgenden Code:
Delphi-Quellcode:
Im onShow der Form wird das Backup gestartet.
procedure TfrmBackup.erstelleBackup(Sender: TObject);
var sPfad,sDateiTime,sDateiWWS, sTempPath: String; begin sDateiTime := Tage[DayOfWeek(Now)] + 'Backup.zip'; sTempPath := frmBackUp.GetTimeIniPath + 'BackupTemp\'; if not connectBackupTime.IsConnected then connectBackupTime.Connect; qWork_Time.SQL.Text := 'EXECUTE PROCEDURE sp_BackupDatabase(' + QuotedStr(sTempPath + 'DB\') + ',NULL)'; qWork_Time.ExecSQL; DBZip(sDateiTime,sTempPath + 'Time\'); end; Nun habe ich folgendes Problem: Manchmal (vieleicht 3 von 10 Fällen) passiert es, das die Anwedung nicht mehr richtig beendet wird (Es kommt diese Windows-Meldung "Das Programm nicht mehr . -> Online nach einer Lösung suchen und das Programm schließen -> Programm schließen" Ich habe den Verdacht, das es daran liegt das die Stored Procedure noch nicht ganz fertig ist und dann schon probiert wird die ZIP-File zu erstellen. Gibt es einen Weg zu checken, ob diese beendet ist? Oder meint ihr es ist etwas anderes? Vielen dank für eure Hilfe! |
AW: Backup mit storedProcedure und anschließendes zippen
Bist Du sicher, dass das Programm bis zum Zippen kommt?
Vielleicht gibt es vorher schon einProblem, dass z.B. die Datei schon existiert oder so... Ich habe ![]() PS: Evtl. hilft ein Application.ProcessMessages. |
AW: Backup mit storedProcedure und anschließendes zippen
Hi,
jo bis zum zippen kommt es auf jeden Fall - das Zip-File wird auch immer erfolgreich erstellt, egal ob die Meldung kommt oder nicht. Das Application.ProcessMessages habe ich getestet, hat leider keine Abhilfe geschaffen... |
AW: Backup mit storedProcedure und anschließendes zippen
Zitat:
und was würde passieren, wenn das Backup mehrmals zur selben Zeit erstellt wird? |
AW: Backup mit storedProcedure und anschließendes zippen
Vielleicht werden im Hintergrund auch Threads verwendet.
|
AW: Backup mit storedProcedure und anschließendes zippen
Das Backup wird in onShow gestartet, weil es nach dem Programmstart automatisch ausgeführt werden soll.
Zur selben Zeit kann kein zweites Backup erstellt, da geprüft wird ob die Anwendung schon läuft.
Code:
Wenn dem so wäre, kann man rauskriegen wann diese Thread abgearbeitet sind?
Vielleicht werden im Hintergrund auch Threads verwendet.
|
AW: Backup mit storedProcedure und anschließendes zippen
Nun ich sehe das als simples Timing-Problem.
Die SP kommt zurück obwohl die Daten noch nicht physikalisch geschrieben sind. Also erst einmal nachschauen ob die Backup-Datei überhaupt (vollständig) existiert, und dann erst zippen. Gruß K-H |
Alle Zeitangaben in WEZ +1. Es ist jetzt 00:49 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 by Thomas Breitkreuz