解决JAVA调用mysqldump备份数据库时文件为空的问题

来源:互联网 发布:淘宝黑莓 编辑:程序博客网 时间:2024/05/24 06:56

问题:系统备份的sql文件为空文件。

mysql的安装路径不一样,软件工具都安装在C盘以外,自定义的安装路径,而有的人是安装在默认的Program Files下面,

文件夹有空格的名称的经常会致使一些莫名其妙的问题出现。
主要是在cmd中空格不会被当做字符

将mysql bin目录下的mysqldump复制放到c盘,并且把系统语句改为

Runtime rt = Runtime.getRuntime();

rt.exec(“cmd /c c:\mysqldump -hlocalhost -uroot -p123456 –opt databaseName>d:\bk.sql”);

文件不再是0KB的空文件。
罪魁祸首是Program Files文件夹的空字符串,不知道当初微软为啥要在中间加个空格。
解决方案就是:

1、将mysqldump.exe复制放到我的项目文件夹下

2、执行备份时,先得到项目部署路径,然后执行

Runtime rt = Runtime.getRuntime();

String path = 获取mysqldump所在路径。

rt.exec(“cmd /c “+path+”\mysqldump -hlocalhost -uroot -p123456 –opt databaseName>d:\bk.sql”);

3、让客户部署时,别将项目部署在含有空格的文件夹下面。

1 0
原创粉丝点击