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,求高手帮忙! 展开
java.lang.Runtime.getRuntime().exec("mysql");
执行后生成了,生成了ak.sql文件但是是空的。如果在CMD下直接执行 mysqldump -u root -proot --opt mysql > C:/Users/success/ak.sql 就可以生成有内容的ak.sql,求高手帮忙! 展开
3个回答
展开全部
应该是一些特殊符被转义了,你可以把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,搞定睡觉了
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
cmd /c mysqldump -u root -proot --opt mysql > C:/Users/success/ak.sql
这样试一下,
再一个,
java.lang.Runtime.getRuntime().exec("mysql");
这个是你手误?应该是mysql不应该是"mysql"
这样试一下,
再一个,
java.lang.Runtime.getRuntime().exec("mysql");
这个是你手误?应该是mysql不应该是"mysql"
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
Java runtime每次只能执行一条command命令,重定向是不支持的,可以用mysqldump的--result-file="输出文件",避免使用重定向符号>,可以解决你的问题
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询