Oracle 定时任务dbms_scheduler
2017-09-19 09:53
274 查看
1. 简介
在Oracle 10g之前,我们通过DBMS_JOB来管理定时任务;
而10g之后,则推荐使用DBMS_SCHEDULER来管理定时任务,因为它提供了更强大的功能和灵活的机制。2. 需要的权限
CREATE JOB -- (必须, 要执行DBMS_SCHEDULER, 需要有create job权限)
CREATE EXTERNAL JOB -- (可选, 创建执行操作系统命令的job时需要)
# 查询用户所拥有的角色以及角色所包含的权限
select * from role_sys_privs where role in (
select granted_role from dba_role_privs where grantee='SCOTT'
) order by role;
# 查询直接授予用户的权限
select * from dba_sys_privs where grantee='SCOTT';
3. 一个简单的Demo
3.1 创建JOB
详细参数可参考: http://docs.oracle.com/cd/E11882_01/appdev.112/e40758/d_sched.htm#ARPLS72960
3.2 查看JOB执行情况
-- 查看已创建的JOB
select job_name, job_type, enabled, state from user_scheduler_jobs;
-- 查看JOB运行日志
select log_id, log_date, status from user_scheduler_job_run_details where job_name='TEST_JOB1';
3.3 删除JOB
exec dbms_scheduler.drop_job('TEST_JOB1');# 相关链接
http://blog.itpub.net/7607759/viewspace-610951
http://docs.oracle.com/cd/E11882_01/appdev.112/e40758/d_sched.htm#ARPLS72300
BYDAY 关键字用来指定每周的哪天运行。BYMONTHDAY 关键字用来指定每月中的哪一天。-1 表示每月最后一天。BYMONTH 关键字用来指定每年的月份。
BYDATE 指定日期。0310就表示3月10日。例如:运行每星期五。(所有这三个例子是等价的。)
FREQ=DAILY; BYDAY=FRI;
FREQ=WEEKLY; BYDAY=FRI;
FREQ=YEARLY; BYDAY=FRI;
设置任务隔一周运行一次,并且仅在周5运行:FREQ=WEEKLY; INTERVAL=2; BYDAY=FRI;
在每月的最后一天运行
FREQ=MONTHLY; BYMONTHDAY=-1;
三月十日开。(两个例子是等价的)
FREQ=YEARLY; BYMONTH=MAR; BYMONTHDAY=10;
FREQ=YEARLY; BYDATE=0310;
设置任务每10隔天运行:REPEAT_INTERVAL => 'FREQ=DAILY; INTERVAL=10';
设置任务在每天的下午4、5、6点时运行:REPEAT_INTERVAL => 'FREQ=DAILY; BYHOUR=16,17,18';
设置任务在每月29日运行:REPEAT_INTERVAL => 'FREQ=MONTHLY; BYMONTHDAY=29';
设置任务在每年的最后一个周5运行:REPEAT_INTERVAL => 'FREQ=YEARLY; BYDAY=-1FRI';
设置任务每隔50个小时运行:REPEAT_INTERVAL => 'FREQ=HOURLY; INTERVAL=50';
repeat_interval => 'FREQ=HOURLY; INTERVAL=2'
每隔2小时运行一次jobrepeat_interval => 'FREQ=DAILY'
每天运行一次jobrepeat_interval => 'FREQ=WEEKLY; BYDAY=MON,WED,FRI"
每周的1,3,5运行jobrepeat_interval => 'FREQ=YEARLY; BYMONTH=MAR,JUN,SEP,DEC; BYMONTHDAY=30'
每年的3,6,9,12月的30号运行job既然说到了repeat_interval,你可能要问:"有没有一种简便的方法来得出,或者说是评估出job的每次运行时间,以及下一次的运行时间呢?"dbms_scheduler包提供了一个过程evaluate_calendar_string,可以很方便地完成这个需求! https://www.cnblogs.com/lanzi/archive/2012/11/23/2784815.html
在Oracle 10g之前,我们通过DBMS_JOB来管理定时任务;
而10g之后,则推荐使用DBMS_SCHEDULER来管理定时任务,因为它提供了更强大的功能和灵活的机制。2. 需要的权限
CREATE JOB -- (必须, 要执行DBMS_SCHEDULER, 需要有create job权限)
CREATE EXTERNAL JOB -- (可选, 创建执行操作系统命令的job时需要)
# 查询用户所拥有的角色以及角色所包含的权限
select * from role_sys_privs where role in (
select granted_role from dba_role_privs where grantee='SCOTT'
) order by role;
# 查询直接授予用户的权限
select * from dba_sys_privs where grantee='SCOTT';
3. 一个简单的Demo
3.1 创建JOB
create table test_t1(id int, create_date date); create or replace procedure test_p1 is v_maxId test_t1.id%type := 1; begin select nvl(max(id), 0) into v_maxId from test_t1; insert into test_t1 values(v_maxId + 1, sysdate); commit; end test_p1; / declare v_count int := 0; begin select count(*) into v_count from user_scheduler_jobs where job_name='TEST_JOB1'; if v_count > 0 then dbms_scheduler.drop_job('TEST_JOB1'); end if; dbms_scheduler.create_job ( job_name => 'test_job1', job_type => 'STORED_PROCEDURE', job_action => 'TEST_P1', start_date => sysdate, repeat_interval => 'FREQ=MINUTELY;INTERVAL=1', enabled => true ); end; /
job_name : 必选, 任务名称 job_type : 必选, 任务类型( PLSQL_BLOCK, -- 执行一个PL/SQL匿名快 STORED_PROCEDURE, -- 执行一个存储过程 EXECUTABLE, -- 执行一个外部程序 CHAIN -- 执行一个CHAIN ) job_action : 必选, 任务内容, 与job_type配合使用 start_date : 可选, 首次执行时间, 为空时表示立即执行 repeat_interval : 可选, 执行频率, 为空时表示只执行一次( FREQ=MINUTELY; -- 表示间隔单位, 可选值有YEARLY, MONTHLY, WEEKLY, DAILY, HOURLY, MINUTELY, SECONDLY INTERVAL=1 -- 表示间隔周期 ) enabled : 可选, 是否启用任务
详细参数可参考: http://docs.oracle.com/cd/E11882_01/appdev.112/e40758/d_sched.htm#ARPLS72960
3.2 查看JOB执行情况
-- 查看已创建的JOB
select job_name, job_type, enabled, state from user_scheduler_jobs;
-- 查看JOB运行日志
select log_id, log_date, status from user_scheduler_job_run_details where job_name='TEST_JOB1';
3.3 删除JOB
exec dbms_scheduler.drop_job('TEST_JOB1');# 相关链接
http://blog.itpub.net/7607759/viewspace-610951
http://docs.oracle.com/cd/E11882_01/appdev.112/e40758/d_sched.htm#ARPLS72300
Oracle Scheduler Jobs
Repeat Interval参数
FREQ 关键字用来指定间隔的时间周期,可选参数有:YEARLY(年), MONTHLY(月), WEEKLY(周), DAILY(日), HOURLY(时), MINUTELY(分), SECONDLY(秒)等单位。INTERVAL 关键字用来指定间隔的频繁,可指定的值的范围从1-999。BYHOUR 指定一天中的小时。可指定的值的范围从1-24。16,17,18就表示每天下午的4、5、6点。BYDAY 关键字用来指定每周的哪天运行。BYMONTHDAY 关键字用来指定每月中的哪一天。-1 表示每月最后一天。BYMONTH 关键字用来指定每年的月份。
BYDATE 指定日期。0310就表示3月10日。例如:运行每星期五。(所有这三个例子是等价的。)
FREQ=DAILY; BYDAY=FRI;
FREQ=WEEKLY; BYDAY=FRI;
FREQ=YEARLY; BYDAY=FRI;
设置任务隔一周运行一次,并且仅在周5运行:FREQ=WEEKLY; INTERVAL=2; BYDAY=FRI;
在每月的最后一天运行
FREQ=MONTHLY; BYMONTHDAY=-1;
三月十日开。(两个例子是等价的)
FREQ=YEARLY; BYMONTH=MAR; BYMONTHDAY=10;
FREQ=YEARLY; BYDATE=0310;
设置任务每10隔天运行:REPEAT_INTERVAL => 'FREQ=DAILY; INTERVAL=10';
设置任务在每天的下午4、5、6点时运行:REPEAT_INTERVAL => 'FREQ=DAILY; BYHOUR=16,17,18';
设置任务在每月29日运行:REPEAT_INTERVAL => 'FREQ=MONTHLY; BYMONTHDAY=29';
设置任务在每年的最后一个周5运行:REPEAT_INTERVAL => 'FREQ=YEARLY; BYDAY=-1FRI';
设置任务每隔50个小时运行:REPEAT_INTERVAL => 'FREQ=HOURLY; INTERVAL=50';
repeat_interval => 'FREQ=HOURLY; INTERVAL=2'
每隔2小时运行一次jobrepeat_interval => 'FREQ=DAILY'
每天运行一次jobrepeat_interval => 'FREQ=WEEKLY; BYDAY=MON,WED,FRI"
每周的1,3,5运行jobrepeat_interval => 'FREQ=YEARLY; BYMONTH=MAR,JUN,SEP,DEC; BYMONTHDAY=30'
每年的3,6,9,12月的30号运行job既然说到了repeat_interval,你可能要问:"有没有一种简便的方法来得出,或者说是评估出job的每次运行时间,以及下一次的运行时间呢?"dbms_scheduler包提供了一个过程evaluate_calendar_string,可以很方便地完成这个需求! https://www.cnblogs.com/lanzi/archive/2012/11/23/2784815.html
相关文章推荐
- Oracle定时任务(1)-DBMS_SCHEDULER
- Oracle定时任务-DBMS_SCHEDULER
- Oracle定时任务dbms_scheduler
- oracle定时任务dbms_job与dbms_scheduler使用方法
- Oracle 使用DBMS_SCHEDULER创建定时任务
- oracle定时任务(dbms_job)
- oracle定时任务(dbms_job)收藏
- oracle 定时任务(DBMS_JOB)
- oracle定时任务(dbms_job)
- oracle中的定时任务dbms_job包的使用
- oracle定时任务(dbms_job)
- oracle数据库定时任务dbms_job的用法详解
- oracle系统包——dbms_job用法(oracle定时任务)
- oracle系统包dbms_job用法(oracle定时任务)
- oracle系统包——dbms_job用法(oracle定时任务)
- oracle定时任务(dbms_job)
- [转]oracle数据库定时任务dbms_job的用法详解
- oracle系统包——dbms_job用法(oracle定时任务)
- [转]oracle定时任务(dbms_job)
- oracle定时任务(dbms_job)