我的异常网 Java Web开发 Java 面试 J2ME J2EE Java相关 Eclipse J2SE .NET分析设计 .NET Framework .NET面试 .NET组件控件 VC J# Delphi .NET报表 C# ASP LINQ .NET新技术 VB Web Service .NET相关 Oracle面试 Oracle认证考试 Oracle管理 Oracle开发 Oracle技术 Java Exception DotNet Exception Oracle Exception
  

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

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

建议你用游标了。

    
    
如异常没有得到解决,请继续查看以下解决方法:
    暂无相关解决方法。
热点异常解决方法
最新异常解决方法
随机异常解决方法