Java實現MySQL數據庫備份

    在作項目的時候,咱們常常會遇到的一個需求就是數據庫備份。如今一個項目java+mysql+windows開發,接着咱們來數據庫備份的問題。
java

    網上有不少例子,例如:mysql

import java.io.IOException;
  
public class db_deal {       
        private static String str=null;       
         public static void backup(){
                 //使用mysqldump來備份數據庫,格式「mysqldump -u username -pPassword --opt database_name > direction/backup_name.sql」
                 str="mysqldump -u root -proot --opt   hjh >  d:/test.sql";   
 
                try { 
                         Runtime rt=Runtime.getRuntime();
                       rt.exec("cmd /c"+str);
                //Runtime.getRuntime().exec(   )這個方法能夠實現對命令的調用。具體內容看API
                 //上面能夠cmd調用控制檯,而後執行str中的字符串表示的命令。
                        System.out.println("successly!");
                } catch (IOException e) { 
                        e.printStackTrace();  
                        System.out.println("something wrong!");                               } 
  
        }
        public static void load(){
                str="mysql -u root -proot j2603  <  d:/test.sql";
                // mysql命令能夠實現數據庫的還原。格式「mysql -u Username  -pPassword   database_name     <     back_up_dir  」
                Runtime rt=Runtime.getRuntime();
                try {
                        rt.exec("cmd /c"+str);
                        System.out.println("restore successly!");
                } catch (IOException e) {
                        e.printStackTrace();
                       System.out.println("restore fail!");
                }
        } 
}
 

    他們的這些程序不是能直接運行的,要把MySQL的bin添加到環境變量,還有MYSQL的路徑不能含有空格,若是大家喜歡能夠嘗試這樣方法。而我不喜歡添加環境變量,因此採用bat批處理文件這種方法
sql

    新建一個文件backup.bat文件放在項目文件目錄下。數據庫

c:
cd C:\Program Files\MySQL\MySQL Server 5.6\bin
mysqldump -u root -p921026 --opt   test >  d:/test1.sql

    第一行的c:爲MySQL安裝的盤,第二行是MySQL的bin文件夾路徑,第三行是執行數據備份。windows

    編寫調用backup.bat的Java程序
api

import java.io.IOException;
public class Backup {
private static String str = null;
private static Backup b=new Backup();
public static void main(String[] args) {
backup();
}
public static void backup() {
str = b.getClass().getResource("/").getFile().toString()+"backup.bat";
try {
Runtime rt = Runtime.getRuntime();
rt.exec(str);
// runtime.getruntime().exec( )這個方法能夠實現對命令的調用。具體內容看api
// 上面能夠cmd調用控制檯,而後執行str中的字符串表示的命令。
System.out.println("successly!");
} catch (IOException e) {
e.printStackTrace();
System.out.println("something wrong!");
}
}
}

    運行程序就能夠實現數據備份啦。
spa

相關文章
相關標籤/搜索