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 创建JOBcreate 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');

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小时运行一次job

repeat_interval => 'FREQ=DAILY'

每天运行一次job

repeat_interval => 'FREQ=WEEKLY; BYDAY=MON,WED,FRI"

每周的1,3,5运行job

repeat_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 user_scheduler_jobs,Oracle 定时任务dbms_scheduler相关推荐

  1. Oracle数据库创建定时任务

    公司有个数据表存储的是文件上传服务器的历史表,有个字段存储的是文件的二进制流,必然要定时删除这个表里面的数据,这个就想到了oracle里面的定时任务. 我们使用的数据库连接工具是pl/sql Deve ...

  2. Oracle 中的定时任务

    一.Oracle 中的定时任务的实例 1.1.创建一个测试表,只有一个 DATE 类型字段 CREATE TABLE TEST_A(TEST_ADD_DATA DATE); 1.2.创建一个自定义存储 ...

  3. Linux下docker安装配置oracle,oracle创建用户并远程连接,实测可用!

    最近在给同学弄毕业设计的数据库,因为oracle在个人电脑上极不稳定,所以他的电脑数据库崩溃了,这时候我就在docker上为他拉了一个oracle,解决了问题. docker的安装共有以下几步,实测没 ...

  4. oracle自动化,Oracle 自动化备份脚本

    备份脚本,基于linux,windows环境需要适当修改. 主脚本,会调用2,3步骤的rman.sql&status.sql $ more main.sh #set env ######### ...

  5. it oracle 培训,Oracle数据库技术培训_OracleDBA数据库工程师_Oracle数据库在线学习视频教程_IT职业培训-51CTO学院_精培学院...

    第一阶段:企业级Oracle数据库实战入门与集群实施 特色:本阶段部分内容为OCP/OCM课程内容,以企业实战项目为主导讲解,实用性更强. 第1章 Oracle数据库高级工程师职业发展与学习方法 第2 ...

  6. 【oracle】oracle经典sql,exception,database link纠错

    [oracle]oracle经典sql,exception,database link纠错 1111-01 oracle经典sql,exception,database link纠错 1.给表tabl ...

  7. oracle v$system_event,45.Oracle杂记——Oracle常用动态视图v$system_event

    45.Oracle杂记--Oracle常用动态视图v$system_event 视图v$system_event 显示一个事件的总共等待. 如果不支持计时机制,那么TIME_WAITED和AVERAG ...

  8. oracle 202,Oracle Certification 1Z0-202题库

    Oracle Other Oracle Certification 1Z0-202 考题名称:Siebel 8 Consultant Exam 版本号:V2.40 更新时间:2011-09-14 考题 ...

  9. oracle安装就是home3,rhel3上安装Oracle(来自Oracle网站)

    http://www.oracle.com/technology/global/cn/pub/articles/smiley_10gdb_install.html 1.从网上下载redhat Ente ...

最新文章

  1. android资源替换方案overlay,Android 运行时资源替换----Runtime Resource Overlay
  2. Jvm(4),保持线程可见性的几种方法
  3. SOA和SaaS的区别
  4. java中的浮点计算
  5. c语言switch语句程序大全,C语言switch语句
  6. [转载] java 枚举Enum源码解析
  7. php7 编译安装,添加扩展 pdo /usr/local/php/bin/phpize 发现没有 configure
  8. 技术分享 | 一文带你了解测试流程体系
  9. Coarse-Grained lock 粗粒度锁
  10. 批处理 Telnet 星球大战 话说我也清楚这是什么东东
  11. idea启动tomcat出现‘D:\Programfiles‘ 不是内部或外部命令,也不是可运行的程序
  12. 电影购票系统软件测试,软件测试(电影售票系统)
  13. 多测师肖sir__金牌高级讲师软件测试___疑难杂症之app端口占用
  14. 企业微信怎么批量加人?怎么管理员工?看看这套系统
  15. facebook下载
  16. static 函数和变量
  17. 深度解析CentOS通过日志反查***
  18. 有一家做BPM的公司叫K2,Gartner和IDC都说好!
  19. linux下通过串口ftp,eftp简单文件传输工具支持串口、网络、Windows、Linux、单片机平台-博客...
  20. 英语语法总结--状语从句

热门文章

  1. 什么是OpenMAX技术分析OpenMAX
  2. 黎曼曲面Riemann Surface
  3. 深度学习框架:GPU
  4. AlexeyAB DarkNet YOLOv3框架解析与应用实践(三)
  5. 深度学习进阶:多分类与TensorFlow
  6. python 创建只读的函数(@property的介绍与使用)
  7. Application Installation Failed
  8. R.Java文件报错
  9. SharePoint 工作流解决方案(一):顺序工作流和状态机工作流
  10. tp5+linux+apache php7.1.30环境下,上传图片报错:mkdir():permission denied