我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Java中CMD命令来备份mysql数据库备份文件出来为0字节问题

短信预约 信息系统项目管理师 报名、考试、查分时间动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Java中CMD命令来备份mysql数据库备份文件出来为0字节问题

Java中CMD命令来备份mysql数据库备份文件出来为0字节问题

Java中CMD命令来备份mysql数据库备份文件出来为0字节问题
https://blog.csdn.net/qq_36936155/article/details/78978242

今天客户打电话来说我们的系统备份的sql文件为空文件。
这让我很凌乱,我们测试过滴,执行很成功嘛。
可客户使用的时候确实是备份失败嘛 ,这是事实。
 
我东测试西测试,在本机咋滴还是没出现这样的问题;
没办法装了个虚拟机,安装了和客户一样的操作系统 ,并且按照客户安装步骤进行部署。
结果,神奇事情出现了,所备份的数据库文件确实是空的,最后是东找西找,又是百度又是谷歌的,还是没有解决。
后来我一想,mysql的安装路径不一样,我都喜欢把软件工具都安装在C盘以外,自定义的安装路径,而客户是安装在默认的Program Files下面,
而文件夹有空格的名称的经常会致使一些莫名其妙的问题出现。
想到就做,我将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文件夹的空字符串,不知道当初微软为啥要在中间加个空格。

我项目的解决方案就是(项目 fhadmin.cn):
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、前提是让客户部署时,别将项目部署在含有空格的文件夹下面。
 
记录下问题的解决方法以供参考。 
本文转自http://www.cnblogs.com/aDust/archive/2012/10/19/mysqldump.html

今天客户打电话来说我们的系统备份的sql文件为空文件。
这让我很凌乱,我们测试过滴,执行很成功嘛。
可客户使用的时候确实是备份失败嘛 ,这是事实。
 
我东测试西测试,在本机咋滴还是没出现这样的问题;
没办法装了个虚拟机,安装了和客户一样的操作系统 ,并且按照客户安装步骤进行部署。
结果,神奇事情出现了,所备份的数据库文件确实是空的,最后是东找西找,又是百度又是谷歌的,还是没有解决。
后来我一想,mysql的安装路径不一样,我都喜欢把软件工具都安装在C盘以外,自定义的安装路径,而客户是安装在默认的Program Files下面,
而文件夹有空格的名称的经常会致使一些莫名其妙的问题出现。
想到就做,我将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、前提是让客户部署时,别将项目部署在含有空格的文件夹下面。
 
记录下问题的解决方法以供参考。 


 

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Java中CMD命令来备份mysql数据库备份文件出来为0字节问题

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Java中CMD命令来备份mysql数据库备份文件出来为0字节问题

Java中CMD命令来备份mysql数据库备份文件出来为0字节问题https://blog.csdn.net/qq_36936155/article/details/78978242今天客户打电话来说我们的系统备份的sql文件为空文件。这让我很凌乱,我们测试过
Java中CMD命令来备份mysql数据库备份文件出来为0字节问题
2021-12-08

编程热搜

目录