AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Backup mit storedProcedure und anschließendes zippen
Thema durchsuchen
Ansicht
Themen-Optionen

Backup mit storedProcedure und anschließendes zippen

Ein Thema von bwolf · begonnen am 28. Jul 2010 · letzter Beitrag vom 30. Jul 2010
Antwort Antwort
bwolf

Registriert seit: 17. Jan 2006
368 Beiträge
 
Delphi 2009 Professional
 
#1

Backup mit storedProcedure und anschließendes zippen

  Alt 28. Jul 2010, 16:10
Datenbank: Advantage Database Server • Version: 9 • Zugriff über: ADS
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!

Geändert von mkinzler (28. Jul 2010 um 16:13 Uhr) Grund: Code-Tag durch Delphi-Tag ersetzt
  Mit Zitat antworten Zitat
Benutzerbild von stahli
stahli

Registriert seit: 26. Nov 2003
Ort: Halle/Saale
4.343 Beiträge
 
Delphi 11 Alexandria
 
#2

AW: Backup mit storedProcedure und anschließendes zippen

  Alt 28. Jul 2010, 16:35
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.
Stahli
http://www.StahliSoft.de
---
"Jetzt muss ich seh´n, dass ich kein Denkfehler mach...!?" Dittsche (2004)
  Mit Zitat antworten Zitat
bwolf

Registriert seit: 17. Jan 2006
368 Beiträge
 
Delphi 2009 Professional
 
#3

AW: Backup mit storedProcedure und anschließendes zippen

  Alt 28. Jul 2010, 17:02
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...
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.079 Beiträge
 
Delphi 12 Athens
 
#4

AW: Backup mit storedProcedure und anschließendes zippen

  Alt 28. Jul 2010, 17:07
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?
Neuste Erkenntnis:
Seit Pos einen dritten Parameter hat,
wird PoSex im Delphi viel seltener praktiziert.
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.858 Beiträge
 
Delphi 11 Alexandria
 
#5

AW: Backup mit storedProcedure und anschließendes zippen

  Alt 28. Jul 2010, 17:09
Vielleicht werden im Hintergrund auch Threads verwendet.
Markus Kinzler
  Mit Zitat antworten Zitat
bwolf

Registriert seit: 17. Jan 2006
368 Beiträge
 
Delphi 2009 Professional
 
#6

AW: Backup mit storedProcedure und anschließendes zippen

  Alt 30. Jul 2010, 13:44
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?
  Mit Zitat antworten Zitat
Benutzerbild von p80286
p80286

Registriert seit: 28. Apr 2008
Ort: Stolberg (Rhl)
6.659 Beiträge
 
FreePascal / Lazarus
 
#7

AW: Backup mit storedProcedure und anschließendes zippen

  Alt 30. Jul 2010, 15:31
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
Programme gehorchen nicht Deinen Absichten sondern Deinen Anweisungen
R.E.D retired error detector
  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 21:15 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