解决JAVA调⽤mysqldump备份数据库时⽂件为空的问题
今天客户打电话来说我们的系统备份的sql⽂件为空⽂件。
这让我很凌乱,我们测试过滴,执⾏很成功嘛。
可客户使⽤的时候确实是备份失败嘛,这是事实。
java xml是什么我东测试西测试,在本机咋滴还是没出现这样的问题;
没办法装了个虚拟机,安装了和客户⼀样的操作系统,并且按照客户安装步骤进⾏部署。
结果,神奇事情出现了,所备份的数据库⽂件确实是空的,最后是东西,⼜是百度⼜是⾕歌的,还是没有解决。
后来我⼀想,mysql的安装路径不⼀样,我都喜欢把软件⼯具都安装在C盘以外,⾃定义的安装路径,⽽客户是安装在默认的Program Files 下⾯,
⽽⽂件夹有空格的名称的经常会致使⼀些莫名其妙的问题出现。
想到就做,我将mysql bin⽬录下的mysqldump复制放到c盘,并且把系统语句改为
Runtime rt = Runtime();
<("cmd /c c:\\mysqldump -hlocalhost -uroot -p123456 --opt databaseName>d:\\bk.sql");
居然成功了,⽂件不再是0KB的空⽂件。⾃此,问题解决。
罪魁祸⾸是Program Files⽂件夹的空字符串,不知道当初微软为啥要在中间加个空格。
我项⽬的解决⽅案就是:
1、将复制放到我的项⽬⽂件夹下
2、执⾏备份时,先得到项⽬部署路径,然后执⾏
Runtime rt = Runtime();
String path = 获取mysqldump所在路径。
<("cmd /c "+path+"\\mysqldump -hlocalhost -uroot -p123456 --opt databaseName>d:\\bk.sql");
3、前提是让客户部署时,别将项⽬部署在含有空格的⽂件夹下⾯。
记录下问题的解决⽅法以供参考。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。