0

0

如何使用DBMS_SCHEDULER管理计划任务JOB

php中文网

php中文网

发布时间:2016-06-07 17:14:33

|

2244人浏览过

|

来源于php中文网

原创

在ORACLE 数据库中,执行计划任务的工具通常都是DBMS_JOB 包。这个包使用简单,历史悠久,目前还在广泛使用中。坦率地讲,这个包

在Oracle 数据库中,执行计划任务的工具通常都是DBMS_JOB 包。这个包使用简单,历史悠久,目前还在广泛使用中。坦率地讲,这个包的功能满足了绝大部分应用的计划任务运行需要,所以生命力才这么强。

但是,我们这里还是要说一下它的不足之处。

在DBMS_JOB 使用中,我们需要知道每一次JOB 执行的时间,,用于判断该JOB 调用的存储过程执行时间。这里你会说,这个在存储过程里也可以实现的,在存储过程中,执行前后加个时间戳记录到日志表中就可以实现。

是的。以前我们在处理这类需求时也是这么做的。

但从ORACLE 10.1 版本开始,ORACLE 开发了一个新的包DBMS_SCHEDULER 。这个包挺复杂的,以至于我在初次学习之后,就没再去用它了。功能太强大了,其实很多我们不需要的。

我们就有这个需求,看看DBMS_SCHEDULER 是如何解决的。

在SQLPLUS 中,使用DBMS_SCHEDULER.CREATE_JOB 创建计划任务,用于调度一个存储过程。

存储过程很简单,我为这个测试而创建的,就是向一张表里插入数据。

CREATE TABLE T1 AS SELECT SYSDATE AS AA FROM DUAL;

CREATE OR REPLACE PROCEDURE SP_TEST_T1 AS

BEGIN

INSERT INTO T1 SELECTD SYSDATE FROM DUAL;

COMMIT;

END;

这个存储过程没有输入输出参数,是为了JOB 调用方便。如果实际运行过程中有参数,我们就写一个存储过程封装它,再放入JOB 中调用。

例如:

CREATE PROCEDURE GATHER_GTJA_STATS

AS

BEGIN

SYS.DBMS_STATS.GATHER_SCHEMA_STATS(OWNNAME => 'GTJA',ESTIMATE_PERCENT => 30,METHOD_OPT => 'FOR ALL INDEXED COLUMNS SIZE AUTO',CASCADE => TRUE,OPTIONS => 'GATHER');

END;

使用DBMS_SCHEDULER.CREATE_JOB 创建一个JOB, 调用存储过程SP_TEST_T1 ,执行间隔2 分钟。这里的JOB_NAME 名称可以自己定义,这个摆脱了DBMS_JOB 中JOB 号不能自定义的缺点。

EXEC DBMS_SCHEDULER.CREATE_JOB(JOB_NAME => 'JOB_SP_TEST_T1',JOB_TYPE => 'STORED_PROCEDURE',JOB_ACTION =>'SP_TEST_T1' ,START_DATE => SYSDATE ,REPEAT_INTERVAL => 'FREQ=MINUTELY; INTERVAL=2');

该命令执行成功后,可以在*_SCHEDULER_JOBS 中看到JOB 的配置值。

SELECT * FROM DBA_SCHEDULER_JOBS;

SELECT * FROM USER_SCHEDULER_JOBS WHERE JOB_NAME='JOB_SP_TEST_T1';

使用该命令新建的JOB ,默认是不执行的,需要将其状态改成可执行状态。

EXEC DBMS_SCHEDULER.ENABLE(NAME => 'JOB_SP_TEST_T1');

可以删除重建它。

EXEC DBMS_SCHEDULER.DROP_JOB(JOB_NAME => 'JOB_SP_TEST_T1');

EXEC DBMS_SCHEDULER.CREATE_JOB(JOB_NAME => 'JOB_SP_TEST_T1',JOB_TYPE => 'STORED_PROCEDURE',JOB_ACTION => 'SP_TEST_T1',START_DATE => TO_DATE('2012-06-12 15:30:00','YYYY-MM-DD HH24:MI:SS') ,REPEAT_INTERVAL => 'FREQ=DAILY');

这个创建过程而言,其实和DBMS_JOB 创建JOB 的差别不大,但DBMS_SCHEDULER 可配置的地方就太多了。执行时间间隔非常非常灵活,这里不做详述了,具体请看ORACLE 官方文档。

DBMS_SCHEDULER 针对每一次JOB 执行,都做了详细记录,因此,可以查询到每一次JOB 执行的时间了。

具体可以查看两类视图*_SCHEDULER_JOB_LOG 和*_SCHEDULER_JOB_RUN_DETAILS 。

SELECT * FROM DBA_SCHEDULER_JOB_LOG;

SELECT * FROM DBA_SCHEDULER_JOB_RUN_DETAILS;

如果嫌日志太多了,可以使用PURGE_LOG 去清理。

EXECUTE DBMS_SCHEDULER.PURGE_LOG;

这个DBMS_SCHEDULER 包的功能太多了,用起来也累,所以很多人还是选择DBMS_JOB 。

看到关于这两个包的不同点的介绍,摘录下来,留着参考。

At first glance it looks like only other names with more human readable schedules fordbms_scheduler , compared to dbms_job . When looking slightly better, there are loads of differences, even in Oracle 10gR1. Currently we are in 11gR2. Every release dbms_scheduler  gets more enhancements, where dbms_job  has been static for many years.

Differences

  • dbms_scheduler has logging
  • dbms_scheduler has external jobs
  • dbms_scheduler has job chains
  • dbms_scheduler has job event handling (can raise and react upon events)
  • dbms_scheduler has resource manager  integration
  • dbms_scheduler has human readable calendar syntax
  • dbms_scheduler can combine different calendars in a new one
  • In 11g extra

  • dbms_scheduler has remote external jobs
  • dbms_scheduler has light weight jobs - generate many low overhead jobs in one tx
  • dbms_scheduler can send mail on job completion
  • dbms_scheduler jobs can have multiple targets
  • dbms_job can only run pl/sql type of jobs in the current database.

    I hope this (in complete list) h

    linux

    热门AI工具

    更多
    DeepSeek
    DeepSeek

    幻方量化公司旗下的开源大模型平台

    豆包大模型
    豆包大模型

    字节跳动自主研发的一系列大型语言模型

    通义千问
    通义千问

    阿里巴巴推出的全能AI助手

    腾讯元宝
    腾讯元宝

    腾讯混元平台推出的AI助手

    文心一言
    文心一言

    文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

    讯飞写作
    讯飞写作

    基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

    即梦AI
    即梦AI

    一站式AI创作平台,免费AI图片和视频生成。

    ChatGPT
    ChatGPT

    最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

    相关专题

    更多
    pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
    pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

    本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

    463

    2026.02.13

    微博网页版主页入口与登录指南_官方网页端快速访问方法
    微博网页版主页入口与登录指南_官方网页端快速访问方法

    本专题系统整理微博网页版官方入口及网页端登录方式,涵盖首页直达地址、账号登录流程与常见访问问题说明,帮助用户快速找到微博官网主页,实现便捷、安全的网页端登录与内容浏览体验。

    135

    2026.02.13

    Flutter跨平台开发与状态管理实战
    Flutter跨平台开发与状态管理实战

    本专题围绕Flutter框架展开,系统讲解跨平台UI构建原理与状态管理方案。内容涵盖Widget生命周期、路由管理、Provider与Bloc状态管理模式、网络请求封装及性能优化技巧。通过实战项目演示,帮助开发者构建流畅、可维护的跨平台移动应用。

    64

    2026.02.13

    TypeScript工程化开发与Vite构建优化实践
    TypeScript工程化开发与Vite构建优化实践

    本专题面向前端开发者,深入讲解 TypeScript 类型系统与大型项目结构设计方法,并结合 Vite 构建工具优化前端工程化流程。内容包括模块化设计、类型声明管理、代码分割、热更新原理以及构建性能调优。通过完整项目示例,帮助开发者提升代码可维护性与开发效率。

    20

    2026.02.13

    Redis高可用架构与分布式缓存实战
    Redis高可用架构与分布式缓存实战

    本专题围绕 Redis 在高并发系统中的应用展开,系统讲解主从复制、哨兵机制、Cluster 集群模式及数据分片原理。内容涵盖缓存穿透与雪崩解决方案、分布式锁实现、热点数据优化及持久化策略。通过真实业务场景演示,帮助开发者构建高可用、可扩展的分布式缓存系统。

    26

    2026.02.13

    c语言 数据类型
    c语言 数据类型

    本专题整合了c语言数据类型相关内容,阅读专题下面的文章了解更多详细内容。

    29

    2026.02.12

    雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法
    雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法

    本专题系统整理雨课堂网页版官方入口及在线登录方式,涵盖账号登录流程、官方直连入口及平台访问方法说明,帮助师生用户快速进入雨课堂在线教学平台,实现便捷、高效的课程学习与教学管理体验。

    14

    2026.02.12

    豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法
    豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法

    本专题汇总豆包AI官方网页版入口及在线使用方式,涵盖智能写作工具、图片生成体验入口和官网登录方法,帮助用户快速直达豆包AI平台,高效完成文本创作与AI生图任务,实现便捷智能创作体验。

    524

    2026.02.12

    PostgreSQL性能优化与索引调优实战
    PostgreSQL性能优化与索引调优实战

    本专题面向后端开发与数据库工程师,深入讲解 PostgreSQL 查询优化原理与索引机制。内容包括执行计划分析、常见索引类型对比、慢查询优化策略、事务隔离级别以及高并发场景下的性能调优技巧。通过实战案例解析,帮助开发者提升数据库响应速度与系统稳定性。

    53

    2026.02.12

    热门下载

    更多
    网站特效
    /
    网站源码
    /
    网站素材
    /
    前端模板

    精品课程

    更多
    相关推荐
    /
    热门推荐
    /
    最新课程
    PostgreSQL 教程
    PostgreSQL 教程

    共48课时 | 9.3万人学习

    Django 教程
    Django 教程

    共28课时 | 4.4万人学习

    Excel 教程
    Excel 教程

    共162课时 | 17.8万人学习

    关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
    php中文网:公益在线php培训,帮助PHP学习者快速成长!
    关注服务号 技术交流群
    PHP中文网订阅号
    每天精选资源文章推送

    Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号