日期:2014-05-16  浏览次数:20614 次

jobs实现定时任务(定时调用存储过程)
存储过程定时执行Job如何写?说实话,对存储过程,我是一点都不了解,网上的资料看的是一头雾水,现在又要用这个来做东西
“每天晚上启动,读取符合条件的记录”,这个要怎么实现?
另外在这个存储过程里怎么调用函数

------解决方法--------------------
每天晚上启动的话,得用job吧。
------解决方法--------------------
begin
  sys.dbms_job.submit(job => :job,
  what => 'addtoWEB_PAYREF_POLICY;',
  next_date => to_date('13-11-2009', 'dd-mm-yyyy'),
  interval => 'trunc(sysdate)+1');
  commit;
end;

------解决方法--------------------
Job是定时执行存储过程
上面例子中的addtoWEB_PAYREF_POLICY就是要执行的过程名
在过程中可以调用函数,怎么调用..你把函数当个值来处理就行了
------解决方法--------------------
java程序中,调用

存储过程:String proc = "{call proc_name(?,?) }";
几个参数几个问号('?')。
CallableStatement cstmt = conn.prepareCall(procedure); 之后设置参数
cstmt.setString(1,param1); 注意序号从1开始!
cstmt.setInt(2,param2);
cstmt.executeUpdate();
cstmt.close();

函数:String proc = "{ ? = call proc_name(?,?) }";
几个参数几个问号('?')。
CallableStatement cstmt = conn.prepareCall(procedure); 之后设置参数
cstmt.registerOutParameter(1,OracleTypes.INTEGER); 注意序号从1开始!
cstmt.setString(2,param1);
cstmt.setInt(3,param2);
cstmt.executeUpdate();
retVal = cstmt.getInt(1); //这里是获取返回值。
cstmt.close();

你这个需求,用job再好不过了,根本不用写代码,全部丢给数据库去做。
------解决方法--------------------
select * into order_time from t_busi_order_dtl
看你的where条件!这张表存在多个列,要用游标。
另外就是查询结果如果是多于一行数据,select into会出错的。

建议你用游标了。