为什么 process.waitFor();没有起作用 ?
请问为什么下面的cstat = conn.prepareCall("{call sp_load_data(?,?,?)}");未等第一句执行完成就执行了,也就是process.waitFor();没有起到作用。谢谢!
Process process = Runtime.getRuntime().exec(cmdStr);
process.waitFor();//等候
cstat = conn.prepareCall("{call sp_load_data(?,?,?)}");
搜索更多相关主题的帖子:
process waitFor load call data
----------------解决方案--------------------------------------------------------
难道都没有人知道
----------------解决方案--------------------------------------------------------
全部代码帖上来
----------------解决方案--------------------------------------------------------
fileWriter = new FileWriter(rootPath + File.separator + "sqlldr" + "\\sqlldr.txt");
fileWriter.write("userid=irmsp/jrirmsp@ora920");
fileWriter.write(10);
fileWriter.write("csqlldr\\sqlldr.ctl");
fileWriter.write(10);
fileWriter.write("log = " + task.getIrms().getInstallPath() + File.separator + "sqlldr\\logon.log");
fileWriter.write(10);
fileWriter.write("bad = " + task.getIrms().getInstallPath() + File.separator + "sqlldr\\logon.bad");
fileWriter.write(10);
fileWriter.write("errors=30");
fileWriter.write(10);
fileWriter.write("direct=true");
fileWriter.write(10);
fileWriter.close();
stmt.execute("truncate table UNITDICTIONARY_"+period+major_id+"_TEMP");
String cmdStr = "cmd.exe /c start " + task.getIrms().getInstallPath() + "\\sqlldr\\sqlldr.bat";
Process process = Runtime.getRuntime().exec(cmdStr);
System.out.println("Runtime.getRuntime()=" + Runtime.getRuntime() +" startTime=" + startTime);
process.waitFor();
cstat = conn.prepareCall("{call sp_load_data(?,?,?)}");
// cstat.setInt(1, period);
cstat.setString(1, period);
cstat.setString(2, major_id);
cstat.setString(3, rep_date);
cstat.executeUpdate();
conn.commit();
cstat.close();
cstat = null;
代码只是一部分(全部太多)
但是别的只是fileWriter.write的重复写东西
应该不影响大家对程序的理解
[[italic] 本帖最后由 北极光 于 2007-12-4 11:05 编辑 [/italic]]
----------------解决方案--------------------------------------------------------
你起的是一个BAT,那又不是一个进程,它有没有结束,谁知道
你要起就起一个正规的进程
----------------解决方案--------------------------------------------------------
那怎么起啊
这个没弄过哦
现在的也是我临时抱佛脚上网搞得
----------------解决方案--------------------------------------------------------
你非要起进程干嘛啊,你想要实现什么?
----------------解决方案--------------------------------------------------------
我想实现的是先用sqlload把数据加到oracle的临时表里
然后调用存储过程把数据写到实际表中
但是现在sqlload还没把数据加到临时表里
存储过程就运行完了
所以我就想让程序等到sqlload执行完成之后再调用存储过程
----------------解决方案--------------------------------------------------------
我没有弄过多线程
不知道你有没有别的什么好的办法
----------------解决方案--------------------------------------------------------
你就用单线程解决啊
----------------解决方案--------------------------------------------------------