| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 4262 人关注过本帖
标题:为什么 process.waitFor();没有起作用 ?
取消只看楼主 加入收藏
北极光
Rank: 1
等 级:新手上路
帖 子:61
专家分:0
注 册:2006-10-24
收藏
 问题点数:0 回复次数:8 
为什么 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 
2007-12-03 14:25
北极光
Rank: 1
等 级:新手上路
帖 子:61
专家分:0
注 册:2006-10-24
收藏
得分:0 
难道都没有人知道
2007-12-04 06:42
北极光
Rank: 1
等 级:新手上路
帖 子:61
专家分:0
注 册:2006-10-24
收藏
得分:0 
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]]
2007-12-04 10:51
北极光
Rank: 1
等 级:新手上路
帖 子:61
专家分:0
注 册:2006-10-24
收藏
得分:0 

那怎么起啊
这个没弄过哦

现在的也是我临时抱佛脚上网搞得
2007-12-04 11:11
北极光
Rank: 1
等 级:新手上路
帖 子:61
专家分:0
注 册:2006-10-24
收藏
得分:0 
我想实现的是先用sqlload把数据加到oracle的临时表里
然后调用存储过程把数据写到实际表中

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

所以我就想让程序等到sqlload执行完成之后再调用存储过程
2007-12-04 11:22
北极光
Rank: 1
等 级:新手上路
帖 子:61
专家分:0
注 册:2006-10-24
收藏
得分:0 
我没有弄过多线程

不知道你有没有别的什么好的办法
2007-12-04 11:23
北极光
Rank: 1
等 级:新手上路
帖 子:61
专家分:0
注 册:2006-10-24
收藏
得分:0 
我现在就是解决不了啊

就是上面的程序

你看有什么可以实现的方法吗
2007-12-04 12:02
北极光
Rank: 1
等 级:新手上路
帖 子:61
专家分:0
注 册:2006-10-24
收藏
得分:0 
搞不好多线程
没有看过这方面的

明天就要交东西了
估计看书是来不及了
2007-12-04 12:10
北极光
Rank: 1
等 级:新手上路
帖 子:61
专家分:0
注 册:2006-10-24
收藏
得分:0 
谢谢大家的回答!
结帖!
2007-12-05 22:08
快速回复:为什么 process.waitFor();没有起作用 ?
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.043867 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved