如何调用PL/SQL系统包_DBMS_JOB与DBMS_SCHEDULER定时任务
DBMS_JOB 还在用?先看 Oracle 版本和停用风险
如果您正在维护较老版本的 Oracle 数据库或历史遗留系统,那么对 DBMS_JOB 这个内置包一定非常熟悉。然而,一个至关重要的信息是:自 Oracle 10g 版本起,DBMS_JOB 已被 Oracle 官方正式标记为“弃用(Deprecated)”。 这代表着什么?意味着尽管该功能目前仍可运行,但已不再是 Oracle 技术发展的推荐方向,未来版本中可能会被移除。
免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈
在 Oracle 19c 及后续版本中,您或许仍能调用它,但官方明确不建议在新项目中使用。更重要的是,它缺乏现代作业调度所需的许多关键特性,例如基于时间窗口的执行、与资源管理器(Resource Manager)的集成、更强大的依赖链管理以及完善的日志审计功能。因此,如果您的数据库已升级至 12c 或更高版本,且没有强制维护旧脚本的要求,那么最佳实践是:直接绕过 DBMS_JOB,开始学习和采用更强大的 DBMS_SCHEDULER。
需要注意的是,这两个调度器之间存在“相互隔离”的特性,常常导致混淆。一个典型的报错是:ORA-27475: “JOB_NAME” must be a job。这通常是因为开发者误将 DBMS_JOB 创建的作业,当作 DBMS_SCHEDULER 的对象进行查询或操作。例如,在 DBA_SCHEDULER_JOBS 视图中查找不到 DBMS_JOB 创建的任务;反之,DBA_JOBS 视图也绝对看不到任何由 DBMS_SCHEDULER 创建的作业。
- Oracle 10g–11g 环境:可继续使用
DBMS_JOB维持现有系统运行,但强烈建议不要为其开发新的业务逻辑。 - Oracle 12c 及以上版本:所有新建任务都应使用
DBMS_SCHEDULER。如需迁移旧任务,需特别注意权限变更——DBMS_SCHEDULER要求明确的CREATE JOB系统权限,取代了原先DBMS_JOB所依赖的CREATE PROCEDURE权限。 - 视图完全独立:
DBMS_JOB创建的作业不会出现在任何DBA_SCHEDULER_*相关视图中,两者是完全独立的管理体系。
DBMS_SCHEDULER.CREATE_JOB 最简可用写法
初次接触 DBMS_SCHEDULER,很容易被其众多的参数和组件(如 Schedule、Program、Job Class)所困扰。其实,对于大多数一次性或简单的周期性任务,有一种更直接、不易出错的方法:使用内联(Inline)方式创建作业。 无需一开始就拆分组件,先用最简写法快速实现功能。
考虑一个典型需求:需要在每天凌晨2点执行一个名为 pkg_clean.upd_stats 的存储过程。使用内联方式创建作业的代码如下:
BEGIN
DBMS_SCHEDULER.CREATE_JOB(
job_name => 'DAILY_STATS_UPDATE',
job_type => 'STORED_PROCEDURE',
job_action => 'pkg_clean.upd_stats',
start_date => TRUNC(SYSDATE) + 2/24,
repeat_interval => 'FREQ=DAILY; BYHOUR=2; BYMINUTE=0',
enabled => TRUE,
comments => 'Daily stats refresh'
);
END;
这段代码虽然简洁,但几个关键细节决定了作业能否成功运行:
job_type参数选择:该参数主要有三个常用值:'PLSQL_BLOCK'(用于执行匿名 PL/SQL 块,块内容需以分号结尾)、'STORED_PROCEDURE'(只需填写存储过程名,切勿添加括号和参数)、'EXECUTABLE'(调用操作系统命令或脚本,需额外配置操作系统凭证)。选错类型将直接导致作业执行失败。repeat_interval语法规则:它遵循的是 IETF RFC 2445 日历表达式标准,并非 Linux 系统的 cron 表达式。例如,写BYDAY=MON,WED,FRI是合法的,但如果误写成0 0 * * 1,3,5,则会立即触发ORA-27467语法错误。start_date的常见陷阱:如果该参数简单地设置为SYSDATE,作业将在创建成功后立即触发执行一次。许多开发者遇到的“为何新建作业立刻运行了两次?”问题,根源往往在于此。
权限、所有者与运行上下文三大易错点
作业创建成功,但运行时却报权限错误?这可能是 DBMS_SCHEDULER 中最令人困惑的问题之一。其核心原则是:作业默认以创建者(所有者)的身份和权限在后台运行,而非以当前启用或修改它的用户身份执行。
常见的错误现象包括:作业日志中报告 ORA-01031: insufficient privileges,或存储过程执行时提示 ORA-00942: table or view does not exist,但手动登录该用户执行却完全正常。
- 创建作业的权限:创建作业的用户必须拥有
CREATE JOB系统权限。DBA角色包含此权限,但普通开发账号通常需要单独授权。 - 作业执行的权限:作业执行时,使用的是作业所有者的权限。关键点在于:通过角色(Role)授予的权限在存储过程内部是无效的。举例说明,如果用户
SCOTT创建了作业,而作业调用的过程pkg_clean.upd_stats内部需要查询HR.EMPLOYEES表,那么SCOTT必须被直接授予(Direct Grant)该表的 SELECT 权限,仅通过角色拥有该权限是无法成功执行的。 - 对象引用的完整性:当作业调用的存储过程不在当前用户 Schema 下时,
job_action参数必须使用全限定名。例如,应写为'hr.pkg_clean.upd_stats',仅写'pkg_clean.upd_stats'会导致ORA-27477错误。
查看状态、修改时间、停止任务的实用命令
作业部署上线后,日常运维离不开监控与调整。无需翻阅大量文档,掌握以下几个最实用的命令和视图即可应对大部分场景:
- 查看作业状态:要检查作业是否启用、上次执行时间、当前状态及错误信息,可查询此视图:
SELECT job_name, enabled, last_start_date, state, failure_count, additional_info FROM dba_scheduler_jobs WHERE job_name = 'DAILY_STATS_UPDATE';
- 临时停用与恢复执行:如需暂停作业但保留定义,使用
DBMS_SCHEDULER.DISABLE('DAILY_STATS_UPDATE');。需要时再启用:DBMS_SCHEDULER.ENABLE('DAILY_STATS_UPDATE');。 - 修改下次运行时间(谨慎操作):
DBMS_SCHEDULER.SET_ATTRIBUTE('DAILY_STATS_UPDATE', 'start_date', SYSTIMESTAMP + INTERVAL '1' HOUR);。请注意,此操作仅影响后续的调度计划,对于已生成在队列中的运行实例,不会产生改变。
真正棘手的问题,往往是 repeat_interval 参数书写错误,导致作业“静默”失效。例如,本意想每小时执行一次,写成了 'FREQ=HOURLY' 却遗漏了关键的 INTERVAL=1。这种情况下,Oracle 可能会静默地忽略整个重复规则,作业状态显示为 ENABLED,但它永远不会再被触发。遇到作业不按预期运行的情况,第一步应是查询 dba_scheduler_job_log 视图,检查近期是否有 FAILED 或 STOPPED 的记录,那里通常隐藏着问题的根源。
游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。
同类文章
mysql如何在Docker环境下实现数据持久化_挂载宿主机目录与环境变量设置
Docker部署MySQL数据持久化全攻略:避免数据丢失的挂载方法与配置要点 Docker中MySQL数据丢失的根本原因与持久化解决方案 直接执行 docker run mysql:8 0 命令启动MySQL容器时,所有数据库文件默认存储在容器内部的临时存储层。一旦容器被移除或重建,位于 var
MongoDB 事务为何会导致 CPU 占用过高_排查不合理查询引起的事务扫描量
事务CPU高主因是未索引查询、snapshot读关注、跨分片协调及聚合误用;应建索引、降级readConcern、单分片操作、禁用事务内聚合。 事务中未加索引的 find 或 update 会触发全集合扫描 MongoDB事务本身其实并不直接消耗大量CPU资源。问题往往出在事务内部:如果执行的查询缺
怎样将添加表外键约束同步至生产环境_DDL脚本生成与执行
外键约束生成DDL前必须确认引用表已存在,检查表、主键名、列名、类型一致性及权限,并注意MySQL与PostgreSQL在语法、锁机制和校验行为上的关键差异。 外键约束生成 DDL 前必须确认引用表已存在 在生产环境给表加外键,失败的原因十有八九很直接:那条alter table add c
如何处理Java日期存入Oracle变成00:00:00_java.sql.Date与java.sql.Timestamp的区别
应使用 ja va sql Timestamp 或 JDBC 4 2+ 的 LocalDateTime 存储带时间的值 在Ja va应用与Oracle数据库交互时,一个相当经典的“坑”就是时间数据的存储。很多开发者会发现,明明代码里传了一个包含时分秒的时间点,存进数据库再查出来,时间部分却莫名其妙地
如何配置物化视图查询重写_ENABLE QUERY REWRITE自动路由SQL至物化视图
物化视图查询重写:为什么你的配置没生效? 在数据库性能优化领域,物化视图的查询重写功能堪称一把利器。但不少朋友都遇到过这样的困惑:明明按照文档一步步配置了,为什么执行计划还是雷打不动地扫描基表?问题往往出在几个容易被忽略的细节上。今天,我们就来把这些关键点逐一拆解清楚。 物化视图需同时开启全局QUE
- 日榜
- 周榜
- 月榜
1
2
3
4
5
6
7
8
9
10
相关攻略
2015-03-10 11:25
2015-03-10 11:05
2021-08-04 13:30
2015-03-10 11:22
2015-03-10 12:39
2022-05-16 18:57
2025-05-23 13:43
2025-05-23 14:01
热门教程
- 游戏攻略
- 安卓教程
- 苹果教程
- 电脑教程
热门话题

