| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 4259 人关注过本帖
标题:为什么 process.waitFor();没有起作用 ?
只看楼主 加入收藏
北极光
Rank: 1
等 级:新手上路
帖 子:61
专家分:0
注 册:2006-10-24
收藏
 问题点数:0 回复次数:13 
为什么 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: 16Rank: 16Rank: 16Rank: 16
来 自:灌水之王
等 级:版主
威 望:155
帖 子:28477
专家分:59
注 册:2006-2-26
收藏
得分:0 
全部代码帖上来

可惜不是你,陪我到最后
2007-12-04 10:18
北极光
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: 16Rank: 16Rank: 16Rank: 16
来 自:灌水之王
等 级:版主
威 望:155
帖 子:28477
专家分:59
注 册:2006-2-26
收藏
得分:0 
你起的是一个BAT,那又不是一个进程,它有没有结束,谁知道

你要起就起一个正规的进程

可惜不是你,陪我到最后
2007-12-04 11:07
北极光
Rank: 1
等 级:新手上路
帖 子:61
专家分:0
注 册:2006-10-24
收藏
得分:0 

那怎么起啊
这个没弄过哦

现在的也是我临时抱佛脚上网搞得
2007-12-04 11:11
千里冰封
Rank: 16Rank: 16Rank: 16Rank: 16
来 自:灌水之王
等 级:版主
威 望:155
帖 子:28477
专家分:59
注 册:2006-2-26
收藏
得分:0 
你非要起进程干嘛啊,你想要实现什么?

可惜不是你,陪我到最后
2007-12-04 11:17
北极光
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: 16Rank: 16Rank: 16Rank: 16
来 自:灌水之王
等 级:版主
威 望:155
帖 子:28477
专家分:59
注 册:2006-2-26
收藏
得分:0 
你就用单线程解决啊

可惜不是你,陪我到最后
2007-12-04 11:40
快速回复:为什么 process.waitFor();没有起作用 ?
数据加载中...
 
   



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

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