oracle定时运行存储过程.doc_第1页
oracle定时运行存储过程.doc_第2页
oracle定时运行存储过程.doc_第3页
全文预览已结束

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

直接运行以下命令则可以实现定时:variable job1 number; begin dbms_job.submit(:job1,ac_detail_data_create;,trunc(sysdate,mm)+6+1/24, trunc(add_months(sysdate,1),mm)+6+1/24); commit;end;dbms_job.submit(:job1,ac_detail_data_create;,trunc(sysdate,mm)+6+1/24, trunc(add_months(sysdate,1),mm)+6+1/24); 第二个参数是存储过程名第三个参数第一次执行时间第四个参数定时时间定时时间的计算方法:每天:trunc(sysdate+1)每周:trunc(sysdate+7)每月:trunc(sysdate+30)每个星期日:next_day(trunc(sysdate),SUNDAY)每天6点:trunc(sysdate+1)+6/24半个小时:sysdate+30/1440如果是存储要带运行参数,则采用以下方法:VARIABLE job number;beginsys.dbms_job.submit(job = :job, what = declare p_cycle_id varchar2(8); result number; resulttext varchar2(1024);begin select to_char(add_months(trunc(sysdate),-1),yyyymm)|01 into p_cycle_id from dual; insert into rpt_error_info(err_code,err_msg) values(seq_rpt_log_id.nextval,to_char(sysdate,yyyymmdd hh24miss)|-|p_cycle_id|-rpt_balance_balance_prc_1-); rpt_summary_1290(p_cycle_id,result,resulttext); insert into rpt_error_info(err_code,err_msg) values(seq_rpt_log_id.nextval,to_char(sysdate,yyyymmdd hh24miss)|-|p_cycle_id|-rpt_balance_balance_prc_1-); commit;end;, next_date = to_date(04-03-2012 02:00:00, dd-mm-yyyy hh24:mi:ss), interval = trunc(add_months(sysdate,1),MM)+2+3/24); commit;end;自己使用实例:定时运行一个存储(带参数的):VARIABLE job number;beginsys.dbms_job.submit(job = :job, what = declare output varchar2(1000);begin p_audit_receipt_freeze(output);end;, next_date = trunc(sysdate+1)+3/24, interval = trunc(add_months(sysdate,1)-10); commit;end;设置时日期是10月15号,运行后,其中next_date是第二天凌晨3点,而interval通过计算后则为月份加一个月减去10天,为11月5号(有疑问)定时运行一个存储(不带参数的):variable job1 number; variable output varchar2(1000);begin dbms_job.submit(:job1,p_audit_receipt_freeze;,trunc(sysdate+1)+3/24, trunc(add_months(sysdate,1)-10); commit;end;设置时日期是10月15号,运行后,其中next_date是第二天凌晨3点,而interval通过计算后则为月份加一个月减去10天,为11月5号(有疑问)以上定时应该改为以下内容:(有待验证)VARIABLE job number;beginsys.dbms_job.submit(job = :job, what = declare output varchar2(1000);begin p_audit_receipt_freeze(output);end;, next_date = to_date(05-12-2012 03:00:00, dd-mm-yyyy hh24:mi:ss), interval = trunc(add_months(sysdate,1),MM)+4+3/24); commit;end;/定义为每个月5号跑数也可以定义不用自动跑的,只跑一次的:VARIABLE job number;beginsys.dbms_job.submit(job = :job, what = declare output varchar2(1000);begin p_audit_receipt_fr

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论