2011-04-26 130 views
2

我想知道如何從mysql數據庫創建備份並恢復它。 我想在我的Java應用程序中使用它。我怎麼能從mysql數據庫備份和恢復日期

mysql> mysql -u root -p 123 -h hostname club <dumpfile.sql; 

但它有這個錯誤:

ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'mysql -u root -p mehdi -h hostname club < dumpfile.sql' at line 1 
+0

您需要從命令行執行此操作,而不是從mySQL內執行 – 2011-04-26 16:32:52

回答

2

mysql -u root -p 123 -h hostname club < dumpfile.sql需要在命令行中的SO,而不是在mysql的控制檯執行。

編輯:在Java中,您可以調用SO過程來做到這一點,或使用一些庫進行備份/恢復。嘗試使用dbunit爲數據庫執行此操作。 我用hunter和dbunit工作正常。

+0

是dbunit的一個程序嗎? – 2011-04-26 16:47:39

+0

我下載了dbunit 1.5.5.jar,現在該如何使用它 – 2011-04-26 16:49:44

1

從Linux中的shell提示符,下面創建轉儲:

mysqldump --add-drop-table -u<username> -p<password> <databasename> > dumpfile.sql 

而且從shell提示符,以下進口轉儲文件到現有數據庫:

mysql -u<username> -p<password> <databasename> < dumpfile.sql 
3
import java.io.IOException; 
/** 
* 
* @author [email protected] 
*/ 

public class DatabaseManager { 

public static boolean backup(String mysqldumpPath, String backupPath) { 
    boolean status = false; 
    String username = "name"; 
    String password = "pword"; 
    String database = "database_name"; 


    String command = "/" + mysqldumpPath + "/mysqldump -u " + username + " -p" + password + " " + database + " -r " + backupPath; 
    try { 
     Process runtimeProcess = Runtime.getRuntime().exec(command); 
     int processComplete = runtimeProcess.waitFor(); 
     if (processComplete == 0) { 
      System.out.println("DatabaseManager.backup: Backup Successfull"); 
      status = true; 
     } else { 
      System.out.println("DatabaseManager.backup: Backup Failure!"); 
     } 
    } catch (IOException ioe) { 
     System.out.println("Exception IO"); 
     ioe.printStackTrace(); 
    } catch (Exception e) { 
     System.out.println("Exception"); 
     e.printStackTrace(); 
    } 
    return status; 
} 
public static boolean restore(String filePath){ 
    boolean status = false; 
    String username = "name"; 
    String password = "pword"; 
    String[] command = new String[]{"mysql", "database_name", "-u" + username, "-p" + password, "-e", " source "+filePath }; 

    try { 
     Process runtimeProcess = Runtime.getRuntime().exec(command); 
     int processComplete = runtimeProcess.waitFor(); 
     if (processComplete == 0) { 
      System.out.println("DatabaseManager.restore: Restore Successfull"); 
      status = true; 
     } else { 
      System.out.println("DatabaseManager.restore: Restore Failure!"); 
     } 
    } catch (IOException ioe) { 
     System.out.println("Exception IO"); 
     ioe.printStackTrace(); 
    } catch (Exception e) { 
     System.out.println("Exception"); 
     e.printStackTrace(); 
    } 
    return status; 
} 

//for testing 
public static void main(String args[]){ 
    String backupName = "D:/DatabaseBackup/backupHvs.sql"; 
    DatabaseManager.restore(backupName); 
} 

} 
0
try { 
     Runtime.getRuntime().exec("/C:\\Program Files\\MySQL\\MySQL Server 5.0\\bin\\mysqldump -uroot -p123456 computer -r D:\\zerso\\backup.sql"); 

     JOptionPane.showMessageDialog(null, " make back up"); 
    } catch (IOException ex) { 
     ex.printStackTrace(); 
     JOptionPane.showMessageDialog(null, " not back up"); 
    } catch (Exception e) { 
     System.out.println("Exception"); 
     e.printStackTrace(); 
+1

這看起來像Hanba已經提出的。雖然他的例子更加強大,因爲它等待完成過程。 – Leigh 2012-06-28 16:43:17