Java程序实现mysql数据库导出,命令执行成功了,可是导出的文件是空的,求解!

代码如下:Stringmysql="cmd/kmysqldump-uroot-proot--optmysql>C:/Users/success/ak.sql";java.... 代码如下:String mysql="cmd /k mysqldump -u root -proot --opt mysql > C:/Users/success/ak.sql ";
java.lang.Runtime.getRuntime().exec("mysql");
执行后生成了,生成了ak.sql文件但是是空的。如果在CMD下直接执行 mysqldump -u root -proot --opt mysql > C:/Users/success/ak.sql 就可以生成有内容的ak.sql,求高手帮忙!
展开
 我来答
汪雄辉拉
推荐于2017-11-25 · TA获得超过2966个赞
知道大有可为答主
回答量:1430
采纳率:0%
帮助的人:1641万
展开全部
应该是一些特殊符被转义了,你可以把mysqldump -u root -proot --opt mysql > C:/Users/success/ak.sql 这句写到一个bat文件里面,然后java中就直接调用这个bat文件就可以避免了
更多追问追答
追问
java里面怎么执行项目目录里的bat啊? 我写了个a.bat 放在项目的同级目录下,可是执行
String command = "cmd /k a.bat";
Process child = Runtime.getRuntime().exec(command);
child.waitFor();
并没有执行a.bat
追答
留Q,搞定睡觉了
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友845f74e61
2012-04-26 · TA获得超过6929个赞
知道大有可为答主
回答量:4050
采纳率:50%
帮助的人:1628万
展开全部
cmd /c mysqldump -u root -proot --opt mysql > C:/Users/success/ak.sql

这样试一下,
再一个,
java.lang.Runtime.getRuntime().exec("mysql");

这个是你手误?应该是mysql不应该是"mysql"
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
AllenWwong
2018-05-25
知道答主
回答量:4
采纳率:0%
帮助的人:2.3万
展开全部
Java runtime每次只能执行一条command命令,重定向是不支持的,可以用mysqldump的--result-file="输出文件",避免使用重定向符号>,可以解决你的问题
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式