在作項目的時候,咱們常常會遇到的一個需求就是數據庫備份。如今一個項目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