Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Backup mit storedProcedure und anschließendes zippen (https://www.delphipraxis.net/153302-backup-mit-storedprocedure-und-anschliessendes-zippen.html)

bwolf 28. Jul 2010 15:10

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:
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;
Im onShow der Form wird das Backup gestartet.
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!

stahli 28. Jul 2010 15:35

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 diese Funktionen zum kopieren + komprimieren meiner Datenbanken benutzt (ist alles Delphi-nativ - kann aber nur 1 Datei komprimieren)


PS: Evtl. hilft ein Application.ProcessMessages.

bwolf 28. Jul 2010 16:02

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...

himitsu 28. Jul 2010 16:07

AW: Backup mit storedProcedure und anschließendes zippen
 
Zitat:

Im onShow der Form wird das Backup gestartet.
wieso da?
und was würde passieren, wenn das Backup mehrmals zur selben Zeit erstellt wird?

mkinzler 28. Jul 2010 16:09

AW: Backup mit storedProcedure und anschließendes zippen
 
Vielleicht werden im Hintergrund auch Threads verwendet.

bwolf 30. Jul 2010 12:44

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:
Vielleicht werden im Hintergrund auch Threads verwendet.
Wenn dem so wäre, kann man rauskriegen wann diese Thread abgearbeitet sind?

p80286 30. Jul 2010 14:31

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 08:36 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