oracle怎么写定时器任务,oracle中job定时器任务

对于DBA来说,经常要数据库定时的自动执行一些脚本,或做数据库备份,或做数据的提炼,或做数据库的性能优化,包括重建索引等等的工作。但是,Oracle定时器Job时间的处理上,千变万化,今天我把比较常用写法汇总如下:

在总结之前,先把Job的参数一一说明一下:

job参数是由Submit()过程返回的binary_ineger。这个值用来唯一标识一个工作;

what参数是将被执行的PL/SQL代码块;

next_date参数指识何时将运行这个工作。写Job的时候可以不指定该值;

interval参数何时这个工作将被重执行。

其中Interval这个值是决定Job何时,被重新执行的关键。

例如:有存储过程 p_dosomethings,需要被不同的时间间隔执行。

3e1d642a9a8abe1392cefbb8b98aa605.gifdeclare   

3e1d642a9a8abe1392cefbb8b98aa605.gif  jobno number;   

3e1d642a9a8abe1392cefbb8b98aa605.gifbegin   

3e1d642a9a8abe1392cefbb8b98aa605.gif  dbms_job.submit(

3e1d642a9a8abe1392cefbb8b98aa605.gif    jobno,

3e1d642a9a8abe1392cefbb8b98aa605.gif    'p_dosomething;',  --what

3e1d642a9a8abe1392cefbb8b98aa605.gif    to_date('20090101020000','yyyy-mm-dd hh24:mi:ss'),--next_date,可以不填

3e1d642a9a8abe1392cefbb8b98aa605.gif    'Interval时间字符串'--interval,关键设置

3e1d642a9a8abe1392cefbb8b98aa605.gif  );   

3e1d642a9a8abe1392cefbb8b98aa605.gif  commit;

3e1d642a9a8abe1392cefbb8b98aa605.gifend;

建一个JOB,定时执行不带参数的函数:

DECLARE

job        BINARY_INTEGER; --任务ID

v_begin    DATE; --开始时间

v_interval VARCHAR2(50); --时间间隔

BEGIN

v_begin    := TRUNC(SYSDATE) + 12/24; --

v_interval := 'SYSDATE +1';    --

DBMS_JOB.submit(job,                  --JOB编号

sg_wf_zxcf_syn;',    --what值

v_begin,              --下一个日期

v_interval,           --间隔

FALSE,

0,                    --合计时间

FALSE);

DBMS_OUTPUT.put_line('JOB(任务)编号:' || job);

COMMIT;

END;

//常见的时间写法

1、 每分钟执行

Interval => TRUNC(sysdate,’mi’) + 1 / (24*60)

2、 每天定时执行

例如:每天的凌晨2点执行

Interval => TRUNC(sysdate) + 1 +2 / (24)

3、 每周定时执行

例如:每周一凌晨2点执行

Interval => TRUNC(next_day(sysdate,2))+2/24 --星期一,一周的第二天

4、 每月定时执行

例如:每月1日凌晨2点执行

Interval =>TRUNC(LAST_DAY(SYSDATE))+1+2/24

5、 每季度定时执行

例如每季度的第一天凌晨2点执行

Interval => TRUNC(ADD_MONTHS(SYSDATE,3),'Q') + 2/24

6、 每半年定时执行

例如:每年7月1日和1月1日凌晨2点

Interval => ADD_MONTHS(trunc(sysdate,'yyyy'),6)+2/24

7、 每年定时执行

例如:每年1月1日凌晨2点执行

Interval =>ADD_MONTHS(trunc(sysdate,'yyyy'),12)+2/24

8、 SQL语句

-------------查询JOB-----------------

select job, what, next_date, next_sec, sysdate, failures, broken,interval

from user_jobs a;

-------------添加JOB-----------------

variable n number;

begin

dbms_job.submit(:n, 'MY_JOP;', sysdate,'sysdate+2/(24*60*60)');

commit;

end;

-------------修改JOB-----------------

begin

dbms_job.change(62 ,'MY_JOP;', sysdate,'sysdate+2/(24*60)' );

commit;

end;

begin

dbms_job.change(62 ,'MY_JOP;', to_date('2011-08-01 22:00:00', 'yyyy-mm-dd hh24:mi:ss'),'sysdate+1');

commit;

end;

-------------删除JOB-----------------

begin

dbms_job.remove(41);

end;

-------------运行Job-----------------------

begin

dbms_job.run(41);

end;

9、JOB案例:

建一个JOB,定时执行带参数的函数:

DECLARE

job        BINARY_INTEGER; --任务ID

v_begin    DATE; --开始时间

v_interval VARCHAR2(50); --时间间隔

BEGIN

v_begin    := TRUNC(SYSDATE) + 12/24; --

v_interval := 'SYSDATE +1';    --

DBMS_JOB.submit(job,                  --JOB编号

'declare V_SUMSG varchar(200);V_SUMWF varchar(200); V_SUMZXCF varchar(200); begin sg_wf_zxcf_syn(V_SUMSG,V_SUMWF,V_SUMZXCF);end;',    --what值

v_begin,             --下一个日期

v_interval,           --间隔

FALSE,

0,                    --合计时间

FALSE);

DBMS_OUTPUT.put_line('JOB(任务)编号:' || job);

COMMIT;

END;

关于Oracle中job定时器(通过create_job创建的)配置示例

begin dbms_scheduler.create_job(job_name => 'JOB_BASIC_STATISTIC', job_type => 'STORED_PROCEDU ...

Oracle中job的实例

一.Oracle定时器(Job)各时间段写法汇总 对于DBA来说,数据库Job再熟悉不过了,因为经常要数据库定时的自动执行一些脚本,或做数据库备份,或做数据的提炼,或做数据库的性能优化,包括重建索引等 ...

Oracle中varchar,varchar2,nvarchar,nvarchar2的区别及其它数据类型描述

--varchar,varchar2 联系: 1.varchar/varchar2用于存储可变长度的字符串 比如varchar(20),存入字符串'abc',则数据库中该字段只占3个字节,而不是20个 ...

Oracle中如何实现Mysql的两表关联update操作

在看的时候,发现MySQL提供了一种两表关联update操作.原文如下: UPDATE items,month SET items.price=month.p ...

ORACLE中的LTRIM、RTRIM和TRIM

LTRIM.RTRIM和TRIM在ORACLE中的用法:1.LTRIM(C1,C2)其中C1和C2都可以字符串,例如C1是'Miss Liu',C2'MisL'等等.这是第一个和SQL SERVER不 ...

oracle中临时表是用来做什么的

oracle中临时表是用来做什么的 某些情况下, 需要 多个非常大的表关联的情况下, 但是需要检索的, 是少量的数据的时候.可以先把 大表的数据, 检索出那一小部分, 然后插入到 临时表中, 最后再关 ...

Oracle 中 decode 函数用法

Oracle 中 decode 函数用法 含义解释:decode(条件,值1,返回值1,值2,返回值2,...值n,返回值n,缺省值) 该函数的含义如下:IF 条件=值1 THEN RETURN(翻译 ...

ORACLE 中ROWNUM用法总结(转)

ORACLE 中ROWNUM用法总结! 对于 Oracle 的 rownum 问题,很多资料都说不支持>,>=,=,between...and,只能用以上符号(<. ...>

在Oracle中恢复被DROP掉的表

在Oracle中可能不小心会DROP掉一个表,如果没有定期做备份的话,将会带来很大的麻烦.如果有的情况下,每天的数据都很重要,而定期备份的周期又稍长,情况恐怕也不容乐观!以前只知道Windows有个回 ...

随机推荐

AJAX 大全

本章内容: 简介 伪 AJAX 原生 AJAX XmlHttpRequest 的属性.方法.跨浏览器支持 jQuery AJAX 常用方法 跨域 AJAX JsonP CORS 简单请求.复制请求.请 ...

AngularJS快速入门指南13:表单

一个AngularJS表单是一组输入型控件的集合. HTML控件 HTML输入型标签标包括: input标签 select标签 button标签 textarea标签 HTML表单 HTML表单将各种 ...

深入&period;net(文件操作)

自己进行数据的“持久化操作”: ----- 数据持久化技术:程序还运行过程中,所有的“中间数据”(加工或处理过程中数据)都存放在内存中,但内存的特点是掉电后数据无法保存,所以需要有种技术能够将存放在内 ...

Mycat配置文件rule&period;xml

打开/conf/rule.xml,对应的分片配置截取内容如下:

C&num;基础(二)拆箱与装箱,循环与选择结构,枚举

一.装箱和拆箱 装箱是将值类型转换为引用类型 eg: Int a=5; Object  o=a; 拆箱是将引用类型转换为值类型 eg: Int a=5; Object  o=a; Int b=(int ...

bouncing-balls

效果如下: 代码目录如下:

Linux下安装Julia1&period;0&period;0

MIT正式发布编程语言Julia 1.0:Python.R.C++三合一! 由于官方文档提示中安装的不是最新的Julia版本,官方的0.7版本安装方法为:                       ...

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值