百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术教程 > 正文

详解Oracle定时任务机制-DBMS_SCHEDULER

mhr18 2024-09-29 13:32 27 浏览 0 评论

概述

关于Oracle定时任务管理一般有两个方式,前面已经介绍了DBMS_JOB这种方式,今天主要介绍下另外一种管理方式:DBMS_SCHEDULE。


DBMS_SCHEDULE

Oracle 10g之前,可以使用dbms_job来管理定时任务。10g之后,Oracle引入dbms_scheduler来替代先前的dbms_job,

在功能方面,它比dbms_job提供了更强大的功能和更灵活的机制/管理。

使用dbms_scheduler创建一个定时任务有两种形式

1)创建1个SCHEDULER来定义计划

1个PROGRAM来定义任务内容,再创建1个JOB,为这个JOB指定上面的SCHEDULER和PROGRAM。

2)直接创建JOB,在参数里面直接指定计划和任务内容。

要执行DBMS_SCHEDULER需要有CREATE JOB权限。

如果要创建外部操作系统命令的job, 还必须有CREATE EXTERNAL JOB权限。

如果要对于某个对象进行操作,必须是它的owner,或者对它具有alter权限,或者有create any job权限。

如果要创建/操作job_class,还需要有MANAGE SCHEDULER权限。job_class都是创建在sys schema中的。


参数说明

1)schedule_name,program_name,job_name

这些名字在整个sql名字空间内必须唯一。比如,job_name不能和某个表名相同。

2)repeat_interval

定义job的计划,可以指定的形式相当丰富,也相当灵活,很强大。

举几个例子

a) 05/02 和 09/22 的 8:00 a.m., 1:00 p.m., 6:00 p.m.

'freq=daily;byhour=8,13,18;byminute=0;bysecond=0;bydate=0502,0922'

b) 每个月的最后一个工作日(注意,INTERVAL如果不指定,默认为1)

'FREQ=MONTHLY;BYDAY=MON,TUE,WED,THU,FRI;BYSETPOS=-1'

c) 1/10开始的5天,即1/10~1/14

BYDATE=0110+SPAN:5D

+表示从指定日期开始;-表示到指定日期结束;

^表示围绕指定日期的n天,如果n为偶数,调整为n+1。

d) 以下三种表示方法等同

BYDATE=0205-OFFSET:2W
BYDATE=0205-14D (the OFFSET: keyword is optional)
BYDATE=0122

3)start_date

实际上是schedule生效的日期,

对于一个定时执行的schedule,实际上的开始日期取决于repeat_interval参数。

如果start_date为null,等同于job被enable的时刻。

Oracle取start_date来作为repeat_interval的default值。

4)end_date

这个时间之后,job将不再被执行。

5)program_type/program_action/number_of_arguments/job_type/job_action

program_type有三种形式,program_action是一个PL/SQL block,不支持参数,number_of_arguments必须为0,必须以分号结尾。

program_action是一个存储过程,注意不支持INOUT or OUT参数,也不支持function.

参数最多255个,可以通过SET_JOB_ARGUMENT_VALUE过程来设定。

job_type类似于program_type,只是多了'CHAIN'这种类型来创建任务链。

6) enabled

如果为TRUE, 创建时候检查program/job有效性,如果通过检查把program/job置为ENABLED.

在program/job使用前必须通过ENABLE过程把它置为ENABLED。

如果program为disabled,仅仅enable一个job,那么job会按计划执行,但是会失败。

7)auto_drop

如果为TRUE, 在job完成之后或者被自动disabled之后job将被自动删除。

如果满足以下条件,job被视为完成。

a) 过了end_date。

b) 达到了最大运行次数(max_runs,可以通过SET_ATTRIBUTE来指定)

c) 非重复任务,即只运行一次的任务,并且已经运行了1次。

如果满足以下条件,job被视为自动disabled.

a) 达到了最大运行失败次数(max_failures,可以通过SET_ATTRIBUTE来指定)

相关数据字典

1) dba_scheduler_jobs/user_scheduler_jobs
Enabling 一个 disabled 状态的job会重设本视图中的RUN_COUNT, FAILURE_COUNT and RETRY_COUNT.
2) dba_scheduler_programs/user_scheduler_programs
3) dba_scheduler_schedules/user_scheduler_schedules
4) dba_scheduler_job_log/dba_scheduler_job_run_details
5) dba_scheduler_job_classes
6) 默认情况下,数据库自身定义了一个PURGE_JOB的任务。

该任务每天凌晨3点钟启动,清除30天前所产生的任务日志。


这块还是需要重点掌握的,概念东西做个理解就行,后面会再整理了下涉及的一些命令,感兴趣的朋友可以关注一下~

相关推荐

甲骨文签署多项大型云协议,其一未来可贡献超300亿美元年收入

IT之家7月1日消息,根据甲骨文Oracle当地时间6月30日向美国证券交易委员会(SEC)递交的FORM8-K文件,该企业在始于2025年6月1日的202...

甲骨文获TEMU巨额合同,后者大部分基础设施将迁移至Oracle云

IT之家6月23日消息,Oracle甲骨文创始人、董事长兼首席技术官LarryEllison(拉里埃里森)在本月早些时候的2025财年第四财季和全财年财报电话会议上表示,Oracle...

Spring Boot 自定义数据源设置,这些坑你踩过吗?

你在使用SpringBoot进行后端开发的过程中,是不是也遇到过这样的问题:项目上线后,数据库连接总是不稳定,偶尔还会出现数据读取缓慢的情况,严重影响了用户体验。经过排查,发现很大一部分原因竟然...

一个开箱即用的代码生成器(一个开箱即用的代码生成器是什么)

今天给大家推荐一个好用的代码生成器,名为renren-generator,该项目附带前端页面,可以很方便的选择我们所需要生成代码的表。首先我们通过git工具克隆下来代码(地址见文末),导入idea。...

低代码建模平台-数据挖掘平台(低代码平台的实现方式)

现在来看一下数据连接。·这里是管理数据连接的空间,点击这里可以新增一个数据连接。·输入连接名称,然后输入url,是通过gdbc的方式去连接的数据库,目前是支持mysql、oracle以及国产数据库达梦...

navicat 17.2.7连接oracle数据库提示加载oracle库失败

系统:macOS15.5navicat版本:navicatpremiumlite17.2.7连接oracle测试报错:加载oracle库失败【解决办法】:放达里面找到程序,显示简介里面勾选“使...

开源“Windows”ReactOS更新:支持全屏应用

IT之家6月17日消息,ReactOS团队昨日(6月16日)在X平台发布系列推文,公布了该系统的最新进展,包括升级Explorer组件,支持全屏应用,从Wine项目引入了...

SSL 推出采用全模拟内置混音技术的模拟调音台Oracle

英国调音台传奇品牌SolidStateLogic宣布推出Oracle——一款采用全模拟内置混音技术的调音台,在紧凑的AWS尺寸机箱内集成了大型调音台的功能。该调音台提供24输入和...

47道网络工程师常见面试题,看看有没有你不会的!

你们好,我的网工朋友。网络工程师面试的时候,都会被问到什么?这个问题其实很泛,一般来说,你肯定要先看明白岗位需求写的是什么。基本上都是围绕公司需要的业务去问的。但不可否认的是,那些最基础的概念,多少也...

汉得信息:发布EBS系统安装启用JWS的高效解决方案

e公司讯,从汉得信息获悉,近日,微软官方宣布InternetExplorer桌面应用程序将于2022年6月15日正式停用。目前大部分客户都是使用IE浏览器打开EBS的Form界面,IE停用后,只能使...

36.9K star ! 推荐一个酷炫低代码开发平台!功能太强!

前言最近在逛github,看看能不能搜罗到一些对自己有帮助的开源软件。不经意间看到一个高star的java开源项目:jeecg-boot。进入在线演示版一看,感叹实在是太牛了!此开源项目不管是给来学习...

Linux新手入门系列:Linux下jdk安装配置

本系列文章是把作者刚接触和学习Linux时候的实操记录分享出来,内容主要包括Linux入门的一些理论概念知识、Web程序、mysql数据库的简单安装部署,希望能够帮到一些初学者,少走一些弯路。注意:L...

手把手教你在嵌入式设备中使用SQLite3

摘要:数据库是用来存储和管理数据的专用软件,使得管理数据更加安全,方便和高效。数据库对数据的管理的基本单位是表(table),在嵌入式linux中有时候它也需要用到数据库,听起来好难,其实就是几个函数...

JAVA语言基础(java语言基础知识)

一、计算机的基本概念什么是计算机?计算机(Computer)全称:电子计算机,俗称电脑。是一种能够按照程序运行、自动高速处理海量数据的现代化智能电子设备。由硬件和软件组成、没有安装过任何软件的计算机称...

再见 Navicat!一款开源的 Web 数据库管理工具!

大家好,我是Java陈序员。在日常的开发工作中,常常需要与各种数据库打交道。而为了提高工作效率,常常会使用一些可视化工具进行操作数据库。今天,给大家介绍一款开源的数据库管理工具,无需下载安装软件,基...

取消回复欢迎 发表评论: