网站首页 > 技术文章 正文
概述
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-18 Oracle酒店管理平台远程命令执行和持卡人数据解密漏洞分析
- 2024-10-18 部署lepus天兔驱动包--Oracle、sqlserver、redis等(网上都没)
- 2024-10-18 技能包:linux环境下搭建Oracle数据库
- 2024-10-18 oracle用dbms_stats包收集统计信息
- 2024-10-18 CentOS7下使用RPM包安装Oracle 19c
- 2024-10-18 pycharm无法使用cx-oracle包,如何解决
- 2024-10-18 oracle 结束被锁的包或存储过程 oracle 结束被锁的包或存储过程是什么
- 2024-10-18 超详细的ORACLE DBMS_ROWID包详解--创建rowids和获取rowid的信息
- 2024-10-18 Oracle PL/SQL进阶编程(第七弹:使用系统包:DBMS_PIPE)
- 2024-10-18 数据库oracle存储过程包和主体的创建
你 发表评论:
欢迎- 590℃几个Oracle空值处理函数 oracle处理null值的函数
- 583℃Oracle分析函数之Lag和Lead()使用
- 570℃0497-如何将Kerberos的CDH6.1从Oracle JDK 1.8迁移至OpenJDK 1.8
- 568℃Oracle数据库的单、多行函数 oracle执行多个sql语句
- 563℃Oracle 12c PDB迁移(一) oracle迁移到oceanbase
- 555℃【数据统计分析】详解Oracle分组函数之CUBE
- 541℃最佳实践 | 提效 47 倍,制造业生产 Oracle 迁移替换
- 536℃Oracle有哪些常见的函数? oracle中常用的函数
- 最近发表
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端react (48)
- 前端aes加密 (58)
- 前端脚手架 (56)
- 前端md5加密 (54)
- 前端路由 (61)
- 前端数组 (73)
- 前端js面试题 (50)
- 前端定时器 (59)
- 前端懒加载 (49)
- Oracle RAC (73)
- oracle恢复 (76)
- oracle 删除表 (48)
- oracle 用户名 (74)
- oracle 工具 (55)
- oracle 内存 (50)
- oracle 导出表 (57)
- oracle 中文 (51)
- oracle的函数 (57)
- 前端调试 (52)
- 前端登录页面 (48)
本文暂时没有评论,来添加一个吧(●'◡'●)