Oracle定时任务:DBMS_JOB与DBMS_SCHEDULER的比较与使用
需积分: 44 31 浏览量
更新于2024-09-13
1
收藏 451KB PDF 举报
Oracle定时执行计划任务是数据库管理系统中的一个重要功能,用于安排和管理周期性的任务执行。在Oracle 10g及之前,主要依赖于DBMS_JOB包进行计划任务的调度。DBMS_JOB提供了一种相对简单的方式来创建和管理定时作业,适用于大多数基础的定时任务需求。
然而,Oracle 10g引入了DBMS_SCHEDULER,这是一个更加强大且灵活的工具,取代了DBMS_JOB。DBMS_SCHEDULER提供了更多的控制选项和高级功能,例如多用户并发执行、调度策略的复杂性提升、任务的调度逻辑和异常处理等,使其在大型企业环境中更为适用。
使用DBMS_JOB创建定时任务的基本步骤包括:
1. 配置系统参数:检查并设置job_queue_processes参数,指定数据库中并发执行的定时作业数量,通常建议设置为10(可以通过alter system set命令调整)。若设置为0,将导致定时作业无法运行,而SNP后台进程(System Nagivation Process)负责这些作业的调度。
2. 启动SNP进程:在启用受限会话模式下启动SNP,通过alter system命令切换到disenablerestricted模式。
3. 创建job:使用dbms_job.submit()函数创建一个新的job,如创建一个每分钟自动向job_test表插入当前系统时间的作业。这个过程涉及定义变量、提交作业、指定执行的SQL语句(在这里是插入sysdate),以及设置执行频率,如'sysdate+1/1440'代表每分钟执行一次。
对于不同的时间间隔设置,DBMS_JOB提供了多种选项:
- 每天凌晨1点执行:trunc(sysdate)+25/24,trunc表示截断日期部分,25/24相当于一天的总秒数。
- 每周一凌晨1点执行:trunc(next_day(sysdate,1))+25/24,next_day函数返回指定星期几的日期。
- 每月1号凌晨1点执行:trunc(last_day(sysdate))+25/24,last_day获取一个月中的最后一天。
- 每季度执行一次:trunc(add_months(sysdate, (quarter_of_month - 1) * 3)),quarter_of_month表示当前月份是第几个季度。
DBMS_SCHEDULER则允许创建更复杂的调度规则,如基于特定日期、时间、事件触发的作业,以及设置作业的优先级、重复周期、持续时间等高级特性。无论是DBMS_JOB还是DBMS_SCHEDULER,都能满足Oracle数据库的定时任务需求,根据项目的具体需求和技术背景选择合适的工具是关键。
2016-01-19 上传
2011-09-06 上传
2019-03-17 上传
2019-06-01 上传
2011-01-29 上传
2011-08-17 上传
2010-10-29 上传
tianshenglong
- 粉丝: 19
- 资源: 6
最新资源
- Android圆角进度条控件的设计与应用
- mui框架实现带侧边栏的响应式布局
- Android仿知乎横线直线进度条实现教程
- SSM选课系统实现:Spring+SpringMVC+MyBatis源码剖析
- 使用JavaScript开发的流星待办事项应用
- Google Code Jam 2015竞赛回顾与Java编程实践
- Angular 2与NW.js集成:通过Webpack和Gulp构建环境详解
- OneDayTripPlanner:数字化城市旅游活动规划助手
- TinySTM 轻量级原子操作库的详细介绍与安装指南
- 模拟PHP序列化:JavaScript实现序列化与反序列化技术
- ***进销存系统全面功能介绍与开发指南
- 掌握Clojure命名空间的正确重新加载技巧
- 免费获取VMD模态分解Matlab源代码与案例数据
- BuglyEasyToUnity最新更新优化:简化Unity开发者接入流程
- Android学生俱乐部项目任务2解析与实践
- 掌握Elixir语言构建高效分布式网络爬虫