首页 游戏 软件 资讯 排行榜 专题
首页
数据库
如何调用PL/SQL系统包_DBMS_JOB与DBMS_SCHEDULER定时任务

如何调用PL/SQL系统包_DBMS_JOB与DBMS_SCHEDULER定时任务

热心网友
96
转载
2026-04-27

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 视图,检查近期是否有 FAILEDSTOPPED 的记录,那里通常隐藏着问题的根源。

来源:https://www.php.cn/faq/2314229.html
免责声明: 游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

相关攻略

别信大众智慧?研究称预测市场真正依赖的是“知情少数派”
web3.0
别信大众智慧?研究称预测市场真正依赖的是“知情少数派”

预测市场的真相:是群体智慧,还是少数人的游戏? 说起预测市场,很多人脑海里会立刻浮现出“群体智慧”这个词。成千上万的用户对事件反赌,最终价格似乎总能精准反映现实概率——这听起来像是民主化预测的完美典范。但最近一项来自伦敦商学院和耶鲁大学的研究,却给这个浪漫的想象泼了一盆冷水。 研究团队发现,像Pol

热心网友
04.27
伊朗警告波斯湾安全形势严峻,霍尔木兹海峡紧张局势加剧
web3.0
伊朗警告波斯湾安全形势严峻,霍尔木兹海峡紧张局势加剧

伊朗议员警告:若安全受威胁,波斯湾航道或陷动荡 伊朗议员法达侯赛因·马利基近日发出警告,称如果伊朗的沿海安全受到威胁,波斯湾和阿曼海将出现不安全局势。这无疑给该地区的航运前景蒙上了一层阴影。与此同时,市场对于霍尔木兹海峡交通将于5月15日恢复正常的预期,也出现了微妙变化,目前概率为14 5%。是的,

热心网友
04.27
Oracle RAC如何检查归档模式?跨节点确认归档归属
数据库
Oracle RAC如何检查归档模式?跨节点确认归档归属

Oracle RAC归档日志全面检查指南:节点级验证与线程归属深度解析 在Oracle RAC集群环境中,归档日志的配置与状态检查是一项需要精细化操作的关键任务。它要求数据库管理员必须对每个节点逐一进行归档模式、路径设置、日志生成状态的审查,并深刻理解日志线程归属的核心逻辑。检查的核心流程是:首先通

热心网友
04.27
Oracle RMAN恢复时如何重命名日志文件_配置日志路径参数
数据库
Oracle RMAN恢复时如何重命名日志文件_配置日志路径参数

解决RMAN恢复时日志文件名冲突引发的 ORA-01157 错误 在使用RMAN执行数据库恢复操作时,若目标磁盘上已存在同名的在线重做日志文件(例如 redo01 log),恢复进程常会中断并抛出 ORA-01157: cannot identify lock data file 错误。值得注意的是

热心网友
04.27
SQL如何查询用户连续达标的天数_窗口函数状态机模型
数据库
SQL如何查询用户连续达标的天数_窗口函数状态机模型

SQL如何查询用户连续达标的天数:窗口函数状态机模型 说起查询“连续达标”天数,很多人的第一反应可能是用日期相减。但这里有个本质问题需要先想清楚:我们到底在识别什么? “连续达标”的本质是识别不间断的满足条件时间序列,需用LAG()判断状态延续性并用SUM() OVER构造段ID,而非依赖日期相减。

热心网友
04.27

最新APP

宝宝过生日
宝宝过生日
应用辅助 04-07
台球世界
台球世界
体育竞技 04-07
解绳子
解绳子
休闲益智 04-07
骑兵冲突
骑兵冲突
棋牌策略 04-07
三国真龙传
三国真龙传
角色扮演 04-07

热门推荐

我国刀具市场发展调研报告
办公文书
我国刀具市场发展调研报告

我国刀具市场发展调研报告 在当今制造业持续升级的背景下,市场调研报告的重要性日益凸显。一份结构清晰、数据翔实的报告,能为决策提供关键参考。以下这份关于我国刀具市场的调研报告,旨在梳理现状、剖析问题,并为未来发展提供借鉴。 当前,国内刀具年销售额约为145亿元,其中硬质合金刀具占比不足25%。这一比例

热心网友
04.27
国内首份空净市场调研报告
办公文书
国内首份空净市场调研报告

国内首份空净市场调研报告 在公众健康意识日益增强的今天,市场报告的重要性不言而喻。一份结构清晰、数据翔实的报告,能为行业描绘出精准的航图。那么,一份优秀的市场调研报告究竟该如何呈现?近期发布的这份国内空气净化器行业蓝皮书,或许能提供一个范本。 市场增长的势头有多强劲?数据显示,国内空气净化器市场正驶

热心网友
04.27
水利工程供水管理调研报告
办公文书
水利工程供水管理调研报告

水利工程供水管理调研报告 在各类报告日益成为工作常态的今天,撰写一份扎实的调研报告,关键在于厘清现状、找准问题、提出思路。这份关于水利工程供水管理的报告,旨在系统梳理情况,为后续决策提供参考。 一、基本情况 横跨区域的**水库及八座枢纽拦河闸,构成了**运河流域防洪与兴利供水的骨干工程体系。自投入运

热心网友
04.27
财产保全申请书范本
办公文书
财产保全申请书范本

财产保全申请书范本 一份规范的财产保全申请书,是启动财产保全程序的关键文书。其核心在于清晰、准确地列明各方信息、诉求与依据。通常,申请书的结构是固定的,但具体内容需要根据案件事实来填充。下面,我们通过几个典型的范本来拆解其中的要点。 篇一:通用格式范本 首先来看一个通用模板。这个模板清晰地勾勒出了申

热心网友
04.27
暑假大学生防台风社会实践调研报告范文
办公文书
暑假大学生防台风社会实践调研报告范文

“防台抗台”活动由学院的积极分子组成,他们踊跃报名,利用暑期时间奉献自己的青春,为社会尽一份力量。 带队的学院分团委书记吕老师点出了活动的深层价值:这不仅是一次能力锻炼,更是学生认识社会、融入社会并最终回馈社会的关键一步。经过这番历练,团队友谊愈发坚固,协作精神显著增强,感恩之心也油然而生。 青春洋

热心网友
04.27