专注收集记录技术开发学习笔记、技术难点、解决方案
网站信息搜索 >> 请输入关键词:
您当前的位置: 首页 > Oracle Exception

存储过程定时执行Job如何写?

发布时间:2010-05-20 14:01:29 文章来源:www.iduyao.cn 采编人员:星星草

存储过程定时执行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会出错的。

建议你用游标了。

    
友情提示:
信息收集于互联网,如果您发现错误或造成侵权,请及时通知本站更正或删除,具体联系方式见页面底部联系我们,谢谢。

其他相似内容:

热门推荐: