写个批处理,来导出Oracle的数据,名字为:c:\t.bat,内容如下:
exp hr/hr file=c:\hr.dmp
然后使用Runtime.getRuntime().exec()函数来执行这个批处理,进程竟然挂起,始终不出结果。dmp文件会生成,但大小为0。
这是个很奇怪的问题,经过不停的尝试,终于找到了解决的办法。代码如下:
使用Runtime执行操作系统命令的时候,如果命令中有空格,会遇到麻烦。JAVA有点弱智,不能像WINDOWS批处理一样,用引号来解决。我使用命令数组版本的exec函数,它也不能正常认识,哎。既然命令数组,是用来把命令、参数分开的,那它为什么还会受命令中的空格干扰??
这时的处理办法是:使用cmd /C start "命令字符串",此时有命令字符串中就要以有空格了。如果是批处理命令,不要忘记在末尾加一个exit,不然Runtime会挂起。
exp hr/hr file=c:\hr.dmp
然后使用Runtime.getRuntime().exec()函数来执行这个批处理,进程竟然挂起,始终不出结果。dmp文件会生成,但大小为0。
这是个很奇怪的问题,经过不停的尝试,终于找到了解决的办法。代码如下:
Process process=Runtime.getRuntime().exec(“c:\\t.bat”);
try {
String line = null;
BufferedReader br =
new BufferedReader(new InputStreamReader(process.getErrorStream()));
//读取ErrorStream很关键,这个解决了挂起的问题。
while ((line = br.readLine()) != null){
System.out.println(line);
}
br = new BufferedReader(new InputStreamReader(process.getInputStream()));
while ((line = br.readLine()) != null){
System.out.println(line);
}
process.waitFor();
}
catch (Exception ioe) {
;
}
使用Runtime执行操作系统命令的时候,如果命令中有空格,会遇到麻烦。JAVA有点弱智,不能像WINDOWS批处理一样,用引号来解决。我使用命令数组版本的exec函数,它也不能正常认识,哎。既然命令数组,是用来把命令、参数分开的,那它为什么还会受命令中的空格干扰??
这时的处理办法是:使用cmd /C start "命令字符串",此时有命令字符串中就要以有空格了。如果是批处理命令,不要忘记在末尾加一个exit,不然Runtime会挂起。