如何调用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 的记录,那里通常隐藏着问题的根源。
相关攻略
想在《暗黑破坏神4》S11赛季体验独特的“站桩反伤”玩法?这套以“荆棘”为核心的圣骑士构筑将是你的绝佳选择。其核心理念在于转换输出模式:无需频繁追击敌人,而是通过强化自身防御与反弹机制,让攻击者承受巨额伤害。通过精心的装备与技能配置,你的角色将化身为一座移动的尖刺堡垒,任何近身攻击的敌人都将自食其果
在众多铭文搭配方案中,攻击向的“破甲+暴击”组合堪称经典中的经典。破甲效果能直接穿透对手的防御,让每一次攻击都更具威胁。而暴击属性则带来了伤害爆发的可能性,一旦触发便能造成成吨伤害。两者相辅相成,无论是在PVE清怪效率上,还是在PVP对决的瞬间爆发中,都能制造出决定性的优势,让对手防不胜防。 防御型
将Vidu生成的动态视频制作成PPT循环背景,主要方法包括:通过剪辑软件手动拼接首尾一致的视频片段以实现无缝循环;利用Vidu的高级运动参数预设,生成易于衔接的动态视频;或将视频转换为GIF文件直接插入,利用其自动循环特性。此外,网页端展示时可嵌入带循环属性的HTML视频代码,实现流畅播放。
宇树科技冲刺资本市场的步伐,正变得愈发清晰。 5月25日,上交所发布公告,定于6月1日召开上市审核委员会会议,审议宇树科技股份有限公司的首发上市申请。在叩响资本市场大门的同时,宇树在线下渠道的布局上也按下了加速键。 就在5月底,宇树具身智能体验馆的亚洲首店,即将在上海静安久光百货正式亮相。而此前不到
截至4月末,全国5G基站总数突破500万,占移动基站近四成。同期5G移动电话用户达12 62亿户,占比近七成,用户规模持续快速扩张,增长势头在全球通信史上亦属罕见。
热门专题
热门推荐
资金费率是永续合约锚定现货价格的关键机制。当合约价高于现货价时,多头需向空头支付费用;反之则由空头付费。费率每8小时结算,通过经济激励促使价格回归。持续付费通常表明持有多单且市场处于正费率状态。交易者可结合现货持仓与空头合约进行套利,赚取费率收益。
人力资源经理统筹公司人力资源事务,涵盖招聘、培训等多方面职责,其岗位说明书既是企业选人的标准,也是员工履职的指南。借助AI写作工具,可提升说明书撰写效率。
九号公司发布鼹鼠自平衡2 0与同频双闪两项核心技术。前者通过算法与系统协同实现车辆自主平衡,提升低速与驻停时的操控便利与安全;后者基于统一授时与软总线架构,实现多车灯光精准同步,增强车队辨识与协同体验。两项技术体现了九号在底层智能架构上的系统突破,推动两轮出
想要在《毒液突击队》中解锁“难以捉摸”成就?这项挑战对玩家的潜行技巧要求极高,但只要掌握正确方法,成功触发的难度将大大降低。其核心秘诀在于:保持全程隐匿状态,确保没有任何敌人察觉到你的存在。 成就目标解析 “难以捉摸”成就的达成条件非常严格:在指定的任务关卡中,你必须完全避免进入敌人的“警觉”或“发
推荐系统常因语义、多模态和意图理解不足产生偏差。通义千问系列模型可针对性补强:通过轻量模型重排序提升相关性,多模态模型确保图文匹配,指令模型解析用户行为提炼兴趣标签,OCR提取图像文字,并结合PID控制算法动态融合多源信息,依据实时反馈自动优化权重。





