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

代码如下: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,求高手帮忙!
最新回答
萌妹子

2025-03-30 06:51:53

应该是一些特殊符被转义了,你可以把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,搞定睡觉了
追问
QQ:2579079477 拜托了
咱門都要狠快乐≥

2025-03-30 03:27:46

cmd /c mysqldump -u root -proot --opt mysql > C:/Users/success/ak.sql

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

这个是你手误?应该是mysql不应该是"mysql"
含朕的龙根

2025-03-30 05:16:57

Java runtime每次只能执行一条command命令,重定向是不支持的,可以用mysqldump的--result-file="输出文件",避免使用重定向符号>,可以解决你的问题