AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

Sicherung mit Myqsldump

Ein Thema von sebastian_buege · begonnen am 6. Mär 2007 · letzter Beitrag vom 6. Mär 2007
Antwort Antwort
Seite 1 von 2  1 2      
sebastian_buege

Registriert seit: 5. Mär 2007
58 Beiträge
 
Delphi 6 Personal
 
#1

Sicherung mit Myqsldump

  Alt 6. Mär 2007, 08:35
GUten Morgen, ich habe mal wieder ein Problem:

Ich habe eine Anwendung wo eine Mysql datenbank im hintergrund läuft. ich möchte nun aus dem program heraus mit hilfe des Tool smysqldump eine Sicherung der Datenbank machen.

ShellExecute(handle,'open','..\Mysql\mysqldump','--databases pze -u root -p > siko_333.sql','',SW_SHOW); Das Programm wird auch gestartet. Es verlangt auch nach dem password. soweit uist alles richtig aber er leitet die ausgabe nicht in die datei um sondern auf den bildschirm.

wo könnte der fehler sein.

Vielen dank
  Mit Zitat antworten Zitat
marabu

Registriert seit: 6. Apr 2005
10.109 Beiträge
 
#2

Re: Sicherung mit Myqsldump

  Alt 6. Mär 2007, 08:45
Hallo Sebastian,

die Behandlung von pipes und redirection ist eine Funktionalität der Shell. Darum musst du beim Aufruf entweder die Shell aufrufen oder alles in einen Befehlsstapel verpacken.

Freundliche Grüße
  Mit Zitat antworten Zitat
sebastian_buege

Registriert seit: 5. Mär 2007
58 Beiträge
 
Delphi 6 Personal
 
#3

Re: Sicherung mit Myqsldump

  Alt 6. Mär 2007, 08:48
Zitat von marabu:
Darum musst du beim Aufruf entweder die Shell aufrufen oder alles in einen Befehlsstapel verpacken.
Danke für die schnelle Antwort. das Problem wenn ich die schell (cmd) aufrufe, weiß ich nicht wie ich dort mit den Parametern umgehen muss. Was genau meinst du mit einem Befehlsstapel
  Mit Zitat antworten Zitat
marabu

Registriert seit: 6. Apr 2005
10.109 Beiträge
 
#4

Re: Sicherung mit Myqsldump

  Alt 6. Mär 2007, 09:01
Dein Befehl und seine Parameter und Schalter bilden dann einen einzigen string - die commandline:

Delphi-Quellcode:
var
  cmd, shell: string;
begin
  shell := GetEnvironmentVariable('COMSPEC');
  cmd := '/C ..\Mysql\mysqldump.exe --databases pze -u root -p > siko_333.sql';
  ShellExecute(0, '', PAnsiChar(shell), PAnsiChar(cmd), '', SW_SHOW);
end;
Getippt und nicht getestet.

Ein Befehlsstapel ist einfach eine CMD-Datei.

Freundliche Grüße
  Mit Zitat antworten Zitat
sebastian_buege

Registriert seit: 5. Mär 2007
58 Beiträge
 
Delphi 6 Personal
 
#5

Re: Sicherung mit Myqsldump

  Alt 6. Mär 2007, 09:08
Zitat von marabu:
shell := GetEnvironmentVariable('COMSPEC');
Was soll dieser Befehl bewirken ?
  Mit Zitat antworten Zitat
marabu

Registriert seit: 6. Apr 2005
10.109 Beiträge
 
#6

Re: Sicherung mit Myqsldump

  Alt 6. Mär 2007, 09:17
So besorgst du dir den vollen Namen der Shell - oder wie willst du das machen?
  Mit Zitat antworten Zitat
sebastian_buege

Registriert seit: 5. Mär 2007
58 Beiträge
 
Delphi 6 Personal
 
#7

Re: Sicherung mit Myqsldump

  Alt 6. Mär 2007, 09:20
Zitat von marabu:
So besorgst du dir den vollen Namen der Shell - oder wie willst du das machen?
Okay ich setzte mein Program aber nur in Windows systemmen ab 2000 bzw. xp ein. kann ich nicht einfach sagen

shell:='cmd';
  Mit Zitat antworten Zitat
marabu

Registriert seit: 6. Apr 2005
10.109 Beiträge
 
#8

Re: Sicherung mit Myqsldump

  Alt 6. Mär 2007, 09:27
Wie du magst.

Die relativen Pfade in deiner Kommandozeile solltest du aber noch auf absolute Pfade umstellen und den Namen der Ausgabedatei parametrisieren.

Freundliche Grüße
  Mit Zitat antworten Zitat
sebastian_buege

Registriert seit: 5. Mär 2007
58 Beiträge
 
Delphi 6 Personal
 
#9

Re: Sicherung mit Myqsldump

  Alt 6. Mär 2007, 09:39
Okay ich schicke dir jetzt mal meinen Quellcode.

Delphi-Quellcode:
var
   cmd:String;
   shell: array [Byte] of Char;
   size: Dword;
begin
     GetEnvironmentVariable('COMSPEC',shell,size);
     cmd := '..\Mysql\mysqldump.exe --databases pze -u root -p > siko_333.sql';
     ShellExecute(0, 'open', shell, PAnsiChar(cmd), '', SW_SHOW);
Also das auslesen der cmd variablen geht . er öffnet auch das kommand fenster - aber nichts weiter .

was kann ich noch tun
  Mit Zitat antworten Zitat
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#10

Re: Sicherung mit Myqsldump

  Alt 6. Mär 2007, 09:48
Nun, er wird die mysqldump.exe nicht finden. Aber das hat marabu doch schon gesagt:
Zitat:
Die relativen Pfade in deiner Kommandozeile solltest du aber noch auf absolute Pfade umstellen
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


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