当前位置: 代码迷 >> Java Web开发 >> 为什么 process.waitFor();没有起作用 ?
  详细解决方案

为什么 process.waitFor();没有起作用 ?

热度:645   发布时间:2007-12-03 14:25:56.0
为什么 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执行完成之后再调用存储过程
----------------解决方案--------------------------------------------------------
我没有弄过多线程

不知道你有没有别的什么好的办法
----------------解决方案--------------------------------------------------------
你就用单线程解决啊
----------------解决方案--------------------------------------------------------
  相关解决方案