注册 登录
编程论坛 J2EE论坛

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

北极光 发布于 2007-12-03 14:25, 4268 次点击
请问为什么下面的cstat = conn.prepareCall("{call sp_load_data(?,?,?)}");未等第一句执行完成就执行了,
也就是process.waitFor();没有起到作用。谢谢!
Process process = Runtime.getRuntime().exec(cmdStr);
 process.waitFor();//等候
cstat = conn.prepareCall("{call sp_load_data(?,?,?)}");
13 回复
#2
北极光2007-12-04 06:42
难道都没有人知道
#3
千里冰封2007-12-04 10:18
全部代码帖上来
#4
北极光2007-12-04 10:51
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();
           ();
           cstat.close();
           cstat = null;



代码只是一部分(全部太多)
但是别的只是fileWriter.write的重复写东西
应该不影响大家对程序的理解

[[italic] 本帖最后由 北极光 于 2007-12-4 11:05 编辑 [/italic]]
#5
千里冰封2007-12-04 11:07
你起的是一个BAT,那又不是一个进程,它有没有结束,谁知道

你要起就起一个正规的进程
#6
北极光2007-12-04 11:11

那怎么起啊
这个没弄过哦

现在的也是我临时抱佛脚上网搞得
#7
千里冰封2007-12-04 11:17
你非要起进程干嘛啊,你想要实现什么?
#8
北极光2007-12-04 11:22
我想实现的是先用sqlload把数据加到oracle的临时表里
然后调用存储过程把数据写到实际表中

但是现在sqlload还没把数据加到临时表里
存储过程就运行完了

所以我就想让程序等到sqlload执行完成之后再调用存储过程
#9
北极光2007-12-04 11:23
我没有弄过多线程

不知道你有没有别的什么好的办法
#10
千里冰封2007-12-04 11:40
你就用单线程解决啊
#11
北极光2007-12-04 12:02
我现在就是解决不了啊

就是上面的程序

你看有什么可以实现的方法吗
#12
longrm2007-12-04 12:03
用多线程吧,看看书就好了
#13
北极光2007-12-04 12:10
搞不好多线程
没有看过这方面的

明天就要交东西了
估计看书是来不及了
#14
北极光2007-12-05 22:08
谢谢大家的回答!
结帖!
1