网站首页 > 技术文章 正文
概述
Oracle 10g之前,可以使用dbms_job来管理定时任务。10g之后,Oracle引入dbms_scheduler来替代先前的dbms_job,在功能方面,它比dbms_job提供了更强大的功能和更灵活的机制/管理。
DBMS_JOB包
DBMS_JOB包中包含有许多过程和方法
注意:执行上面的任何创建/删除/更改任务的过程后一定要马上commit。
否则不仅会造成更改无效,甚至很有可能造成一些奇怪的现象,比如job停止之类,切记!
JOB_QUEUE_PROCESSES
Oracle有专门的后台进程来执行任务队列。后台进程的数量通过JOB_QUEUE_PROCESSES来设置,可以设为0到1000。*JOB_QUEUE_INTERVAL从9i之后就被废弃了。
需要注意,如果配置了最多1000 个Jnnn进程,并不会看到真的有1000 个进程随数据库启动。相反,开始时只会启动一个进程,即作业队列协调器(CJQ0),它在作业队列表中看到需要运行的作业时,会启动Jnnn 进程。
如果Jnnn 进程完成其工作,并发现没有要处理的新作业,此时Jnnn 进程就会退出。
unix下面可以用ps -ef | grep ora_j 查看这些进程(J000, ... J999),
另外还有一个ora_cjq0_xxx的队列管理进程。
作业队列协调器(CJQ0)进程被唤醒时,它首先查看任务队列目录中所有的任务是否当前的时间超过了下一次运行的日期时间。检测到需要该时间立即执行的任务后,这些任务按照下一次执行日期的顺序依次执行。当开始执行一个任务时,其过程如下:
1)以任务所有者的用户名开始一个新的数据库会话。 2)当任务第一次提交或是最后一次被修改时,更改会话NLS设置和目前就绪的任务相匹配。 3)通过interval日期表达式和系统时间,计算下一次执行时间。 4)执行任务定义的PL/SQL 5)如果运行成功,任务的下一次执行日期(next_date)被更新,否则,失败计数加1。
相关数据字典
任务队列中的任务信息可以通过以下几个字典视图来查看。
DBA_JOBS 和USER_JOBS中的字段。
DBA_JOBS_RUNNING的字段含义
dbms_job在oracle 10g后其实就比较少用了,不过建议大家还是做个简单了解,重点掌握dbms_scheduler,后面会分享dbms_scheduler方面的内容,感兴趣的朋友可以关注一下~
猜你喜欢
- 2024-10-14 Oracle 11,Oracle 11g安装教程 oracle11.2.0安装教程
- 2024-10-14 linux安装oracle Linux安装oracle客户端
- 2024-10-14 详细介绍Oracle集合运算 oracle集合操作是什么
- 2024-10-14 Oracle索引详解 oracle索引原理详解
- 2024-10-14 Oracle Linux系统安装教程#oracle
- 2024-10-14 超详细的Linux系统设置Oracle数据库开机自动启动教程
- 2024-10-14 Oracle创建函数语法 oracle创建的函数带有编译错误
- 2024-10-14 Oracle存储过程编写 oracle 存储过程的写法及简单实例
- 2024-10-14 新福利!数据库之Oracle教学视频及电子书籍!进来了资料都是你的
- 2024-10-14 Oracle数据库工程师入门培训实战教程 从Oracle11g 到 Oracle19c
你 发表评论:
欢迎- 05-10如何优化数据库和前端之间的交互?
- 05-10前端代码优化小秘籍(前端优化24条建议)
- 05-10VS Code当中的15个神仙插件,值得收藏
- 05-10如何自己开发一个Google浏览器插件?
- 05-10前端流行框架Vue3教程:14. 组件传递Props效验
- 05-10吃了一年的SU,最好用的插件都在这了
- 05-10前端必看!这款神器让网站界面告别千篇一律
- 05-10程序员请收好:10个非常有用的 Visual Studio Code 插件
- 最近发表
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端md5加密 (49)
- 前端路由 (55)
- 前端数组 (65)
- 前端定时器 (47)
- 前端懒加载 (45)
- 前端接口 (46)
- Oracle RAC (73)
- oracle恢复 (76)
- oracle 删除表 (48)
- oracle 用户名 (74)
- oracle 工具 (55)
- oracle 内存 (50)
- oracle 导出表 (57)
- oracle查询数据库 (45)
- oracle约束 (46)
- oracle 中文 (51)
- oracle链接 (47)
- oracle的函数 (57)
- mac oracle (47)
- 前端调试 (52)
- 前端登录页面 (48)
本文暂时没有评论,来添加一个吧(●'◡'●)