/****@paramfileName保存的文件名*@paramfilePath保存文件路径*@throwsException*/publicvoidbackUp(StringfileName,StringfilePath)throwsException{StringipAddress=property.getPr...
/**
*
* @param fileName 保存的文件名
* @param filePath 保存文件路径
* @throws Exception
*/
public void backUp(String fileName,String filePath) throws Exception{
String ipAddress = property.getProperty("ipnum");// ip =127.0.0.1
String password = property.getProperty("password");// password=zhanglu
String databaseName = property.getProperty("dataname");// 库名 = demo
String userName = property.getProperty("userName") ;//userName =root
String rootPath = System.getProperty("user.dir")+"/config";//获取mysqldump.exe路径
rootPath = checkSpacePath(rootPath);//去掉空格
//定义命令
String cmd = "mysqldump -h" + ipAddress + " -u" + userName + " -p"
+ password + " --default-character-set=utf8 --databases "
+ databaseName + " > " + filePath + "\\" + fileName;
System.out.println("数据库备份CMD命令: "+cmd);
Runtime rt = Runtime.getRuntime();
Process process =rt.exec("cmd /c" + cmd);
InputStreamReader isr = new InputStreamReader(process.getErrorStream());
LineNumberReader input = new LineNumberReader(isr);
String line;
while((line = input.readLine())!= null){
String log = text_backlog.getText().trim();
text_backlog.setText(log+"\r\n"+line);//写入到文本框
}
}
代码图:
//数据库名称是demo
这个是执行备份的方法, 如果执行之后, 控制台输出为:
数据库备份CMD命令: mysqldump -h127.0.0.1 -uroot -pzhanglu --default-character-set=utf8 --databases demo > C:\Users\zhanglu\Desktop\test\2015-01-31.sql
错误信息为:
mysqldump: Got error: 1049: Unknown database '>' when selecting the database,
老是识别不了库名, 没有把demo当做库名, 如果是去掉>前的空格,会出现找不到demo> 数据库...
找了一下午了, 找不到原因, 如果是把控制台里面的命令直接拷贝到cmd中, 完全可以运行,,
请大家帮忙分析一下:
上面提到了mysqldump.exe的路径, 但并没有使用, 刚刚测试使用项目中的exe文件和直接使用mysqldump 的都是一样的错误, 环境是jdk1.7 mysql5.6
展开