0

0

dbms_jobvsOracleScheduler

php中文网

php中文网

发布时间:2016-06-07 15:54:25

|

1344人浏览过

|

来源于php中文网

原创

在oracle 10g之前,我们常使用dbms_job提供的相关软件包来管理oracle数据库中的定时任务,虽然10g之后,更多推荐功能更强大的dbms_scheduler,但由于习惯问题,很多时候还是会用到dbms_job,下面简单介绍下两种工作的用法。 DBMS_JOB 1,参数JOB_QUEUE_PROCE

在oracle 10g之前,我们常使用dbms_job提供的相关软件包来管理oracle数据库中的定时任务,虽然10g之后,更多推荐功能更强大的dbms_scheduler,但由于习惯问题,很多时候还是会用到dbms_job,下面简单介绍下两种工作的用法。

DBMS_JOB

1,参数JOB_QUEUE_PROCESSES
oracle已job queue队列的形式管理定时任务,因此需要先设置JOB_QUEUE_PROCESSES参数为非0的数值,一般10即可
ALTER SYSTEM SET JOB_QUEUE_PROCESSES = 10 scope=both;
2, DBMS_JOB用法及例子

SUBMIT:提交任务到队列

VARIABLE jobno NUMBER
BEGIN
   DBMS_JOB.SUBMIT(:jobno,
      'DBMS_DDL.ANALYZE_OBJECT(''TABLE'',''SYS'', ''TEST'',''ESTIMATE'', NULL, 50);',
      SYSDATE, 'SYSDATE + 1');
   COMMIT;
END;
/
sys@MS4ADB3(dtydb5)> PRINT jobno

     JOBNO
----------
         1

查看任务执行情况
sys@MS4ADB3(dtydb5)> select job,what,NEXT_DATE from dba_jobs;

       JOB WHAT                                                                                                 NEXT_DATE
---------- ---------------------------------------------------------------------------------------------------- -------------------
         1 DBMS_DDL.ANALYZE_OBJECT('TABLE','SYS', 'TEST','ESTIMATE', NULL, 50);                                 2014-04-01 14:16:53

有效job的描述例子如下
'myproc(''10-JAN-99'', next_date, broken);'
'scott.emppackage.give_raise(''JFEE'', 3000.00);'
'dbms_job.remove(job);'

常用的job时间间隔
'SYSDATE + 7'
每隔7天

'SYSDATE + 1/48'
每半个小时

'NEXT_DAY(TRUNC(SYSDATE), ''MONDAY'') + 15/24'
每周一下午三点

'NEXT_DAY(ADD_MONTHS(TRUNC(SYSDATE, ''Q''), 3), ''THURSDAY'')'
每季度的第一个周四

REMOVE
从队列中删除
BEGIN
DBMS_JOB.REMOVE(14144);
END;
/
CHANGE
修改任务的属性
BEGIN
DBMS_JOB.CHANGE(14144, NULL, NULL, 'SYSDATE + 3');
END;
/
WHAT
修改任务的描述
BEGIN
DBMS_JOB.WHAT(1,
      'DBMS_DDL.ANALYZE_OBJECT(''TABLE'',''SYS'', ''T2'',''ESTIMATE'', NULL, 50);');
END;
/
NEXT_DATE
任务下一次执行的时间
BEGIN
DBMS_JOB.NEXT_DATE(14144, SYSDATE + 4);
END;
/
INTERVAL
任务执行的时间间隔

BROKEN
终止任务的执行

RUN
运行任务
BEGIN
DBMS_JOB.RUN(1);
END;
/

查看job的相关信息,可以查看视图DBA_JOBS和DBA_JOBS_RUNNING
sys@MS4ADB3(dtydb5)> SELECT JOB, NEXT_DATE, NEXT_SEC, FAILURES, BROKEN
  2     FROM DBA_JOBS;

       JOB NEXT_DATE           NEXT_SEC                                                           FAILURES BR
---------- ------------------- ---------------------------------------------------------------- ---------- --
         1 2014-04-01 14:39:39 14:39:39                                                                  0 N    


例外,jobs运行失败的日志在alert log里面。

DBMS_SCHEDULER

DBMS_SCHEDULER功能更强大,具有如下优点

Logging of job runs (job history) --job运行的日志
Simple but powerful scheduling syntax (similar to but more powerful than cron syntax) --更简单强大的语法
Running of jobs outside of the database on the operating system (see below)--运行os命令
Resource management between different classes of jobs--资源管理功能
Use of job arguments including passing of objects into stored procedures--使用任务参数
Privilege-based security model for jobs -- 更好的权限控制
Naming of jobs and comments in jobs --job命名和描述
Stored, reusable schedules --存储和重用存储过程

--常见用法
BEGIN
  DBMS_SCHEDULER.create_job (
    job_name        => 'test_full_job_definition',
    job_type        => 'PLSQL_BLOCK',
    job_action      => 'BEGIN DBMS_STATS.gather_schema_stats(''WJ''); END;',
    start_date      => SYSTIMESTAMP,
    repeat_interval => 'freq=hourly; byminute=0',
    end_date        => NULL,
    enabled         => TRUE,
    comments        => 'Job defined entirely by the CREATE JOB procedure.');
END;

运行os命令的例子
BEGIN
  DBMS_SCHEDULER.CREATE_JOB (
     job_name           => 'my_OS_job',
     job_type           => 'EXECUTABLE',
     job_action         => 'ls /tmp',
     repeat_interval    => 'FREQ=MINUTELY',
     enabled            => TRUE
  );
END;

--运行一个job
EXEC dbms_scheduler.run_job('TEST_FULL_JOB_DEFINITION');

SELECT * FROM dba_scheduler_jobs WHERE job_name = 'TEST_FULL_JOB_DEFINITION';

REPEAT_INTERVAL的例子
'FREQ=DAILY; BYDAY=SUN; BYHOUR=18;',
 
'freq=MINUTELY;interval=1',  
 
'freq=MINUTELY;interval=5',  
 
'freq=HOURLY;interval=1',    
 
'FREQ=DAILY; BYDAY=MON,TUE,WED,THU,FRI,SAT,SUN; BYHOUR=22;',

更多关于dbms_scheduler的用法可以常见官方文档

http://docs.oracle.com/cd/E11882_01/server.112/e25494/scheduse.htm#ADMIN13380

Akkio
Akkio

Akkio 是一个无代码 AI 的全包平台,任何人都可以在几分钟内构建和部署AI

下载

参考文档:

http://docs.oracle.com/cd/B10501_01/server.920/a96521/jobq.htm#9499
http://www.mandsconsulting.com/oracle-dbms_scheduler-vs-dbms_job-create-run-monitor-remove
http://docs.oracle.com/cd/E11882_01/server.112/e25494/scheduse.htm#ADMIN13380

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
微信文件过期恢复教程
微信文件过期恢复教程

本专题整合了微信文件过期恢复方法、技巧教程,阅读专题下面的文章了解更多详细内容。

0

2026.02.04

抖音网页版入口与视频观看指南 抖音官网视频在线访问
抖音网页版入口与视频观看指南 抖音官网视频在线访问

本专题汇总了抖音网页版的入口链接、官方登录页面以及视频观看入口,帮助用户快速访问抖音网页版,提供免登录访问方式和直接进入视频播放页面的方法,确保顺利浏览和观看抖音视频。

63

2026.02.04

学习通网页版入口与在线学习指南 学习通官网登录与使用方法
学习通网页版入口与在线学习指南 学习通官网登录与使用方法

本专题详细汇总了学习通网页版入口与登录方法,提供学习通官方网页端入口、学生登录平台、网页版使用指南等内容,帮助用户快速稳定地登录学习通官网,顺利进入学习平台,提升学习效率和体验。

9

2026.02.04

Python Web 框架 Django 深度开发
Python Web 框架 Django 深度开发

本专题系统讲解 Python Django 框架的核心功能与进阶开发技巧,包括 Django 项目结构、数据库模型与迁移、视图与模板渲染、表单与认证管理、RESTful API 开发、Django 中间件与缓存优化、部署与性能调优。通过实战案例,帮助学习者掌握 使用 Django 快速构建功能全面的 Web 应用与全栈开发能力。

9

2026.02.04

Java 流式处理与 Apache Kafka 实战
Java 流式处理与 Apache Kafka 实战

本专题专注讲解 Java 在流式数据处理与消息队列系统中的应用,系统讲解 Apache Kafka 的基础概念、生产者与消费者模型、Kafka Streams 与 KSQL 流式处理框架、实时数据分析与监控,结合实际业务场景,帮助开发者构建 高吞吐量、低延迟的实时数据流管道,实现高效的数据流转与处理。

3

2026.02.04

Golang 容器化与 Docker 实战
Golang 容器化与 Docker 实战

本专题深入讲解 Golang 应用的容器化与 Docker 部署,涵盖 Docker 基础概念、容器构建与镜像管理、Go 应用的 Dockerfile 编写、跨平台容器部署与优化、Docker Compose 和 Kubernetes 部署工具。通过实际案例,帮助学习者掌握 如何将 Golang 应用容器化并实现高效部署与管理,提升系统的可扩展性与运维效率。

3

2026.02.04

全国统一发票查询平台入口合集
全国统一发票查询平台入口合集

本专题整合了全国统一发票查询入口地址合集,阅读专题下面的文章了解更多详细入口。

59

2026.02.03

短剧入口地址汇总
短剧入口地址汇总

本专题整合了短剧app推荐平台,阅读专题下面的文章了解更多详细入口。

110

2026.02.03

植物大战僵尸版本入口地址汇总
植物大战僵尸版本入口地址汇总

本专题整合了植物大战僵尸版本入口地址汇总,前往文章中寻找想要的答案。

56

2026.02.03

热门下载

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

精品课程

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

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