BackUp.bat
Code:
RD /S /Q H:\BackUp\120330
DEL /Q H:\BackUp\120401\*09.sql
DEL /Q H:\BackUp\120401\*15.sql
E:\EXE\pg_dump --disable-triggers -i -f H:\BackUp\120404\ab2.18.sql -t ab2 --column-inserts -F p -a -h
localhost -p 5432 -S xxx -U xxx xxx
E:\EXE\pg_dump --disable-triggers -i -f H:\BackUp\120404\ab2_param.18.sql -t ab2_param --column-inserts -F p -a -h
localhost -p 5432 -S xxx -U xxx xxx
...
BackUpCall.bat
Code:
"E:\EXE\BackUp\BackUp.bat" > "E:\EXE\BackUp\BackUp.1204041827.Log"
Delphi-Quellcode:
ShellExecute(ParentWindow, nil, PChar('C:\Windows\System32\cmd.exe'),
Pointer('/C "E:\EXE\BackUp\BackUp.bat" > "E:\EXE\BackUp\BackUp.1204041827.Log"'), PChar(ExtractFileDir(ParamStr(0))), SW_NORMAL);
//oder
ShellExecute(ParentWindow, nil, PChar('E:\EXE\BackUp\BackUpCall.bat'), nil, PChar(ExtractFileDir(ParamStr(0))), SW_NORMAL);
// oder über die Komandozeile (macht keinen Unterschied, ob ShellExecute oder so)
"E:\EXE\BackUp\BackUp.bat" > "E:\EXE\BackUp\BackUp.1204041827.Log"
// bzw.
"E:\EXE\BackUp\BackUpCall.bat"
Es landen jeweils nur die Befehle aus der BAT in der Log, aber Fehlermeldungen ala "Das System kann die angegebene Datei nicht finden." (DEL kann nichts löschen, da nichts mehr da ist) und die Meldungen der pg_dump.exe landen im CMD-Fenster.
[Edit]
DIR > C:\temp\Dir.txt
wird umgeleitet, ebenso ein bei
DIR
, wenn die ausgabe der BAT umgeleitet wird,
aber scheinbar die "Fehlermeldungen" des RD und die Fehler-/Statusmeldungen der EXE nicht.