oracle dbms_job 写法

dbms_job是Oracle数据库的一个重要组件,它是用于在数据库中定期执行任务的实用程序。我们可以通过使用dbms_job创建和管理定时任务,包括创建脚本、设置参数和定时插入数据。在创建过程中,我们需要注意设置job_queue_processes参数,以控制Oracle能够并发的job的数量。以下是使用dbms_job创建和管理定时任务的一些示例代码和注释:

  1. 创建job:

    BEGIN
    dbms_job.submit(job => :job_name, what => 'job_action', next_date => TO_DATE('01-JAN-2021 00:00:00', 'DD-MON-YYYY HH24:MI:SS'), interval => 'INTERVAL 1 DAY');
    END;

在上面的代码中,我们创建了一个名为:job_name的job,并将其提交到数据库中。该job会在明天凌晨0点开始执行,并以一天为周期进行。

  1. 查看job状态:

    SELECT job, last_date, last_next_date, status
    FROM dba_jobs
    WHERE job = :job_name;

在上面的代码中,我们从dba_jobs表中查询job的状态。其中,job是job的名称,last_date是上一次执行的时间,last_next_date是下一次执行的时间,status是job的状态。

  1. 取消job:

    BEGIN
    dbms_job.remove(job => :job_name);
    END;

在上面的代码中,我们使用dbms_job.remove方法来取消job。

  1. 更新job:

    BEGIN
    dbms_job.change(job => :job_name, what => 'new_action');
    END;

在上面的代码中,我们使用dbms_job.change方法来更新job的操作。其中,new_action是新的操作。

dbms_job在10g后较少使用,dbms_scheduler将成为重点。虽然dbms_job提供了许多过程和方法,但dbms_scheduler功能更强大。Oracle引入dbms_scheduler来管理定时任务,替代dbms_job。我们也可以通过使用dbms_scheduler来实现类似的功能,以下是一个使用dbms_scheduler创建和管理定时任务的示例代码:

  1. 创建job:

    BEGIN
    dbms_scheduler.create_job (job_name => :job_name, job_type => 'PLSQL_BLOCK',
    job_action => 'BEGIN
    -- your code here;
    END;', start_date => sysdate, repeat_interval => 'FREQ=DAILY; BYHOUR=16; BYMINUTE=00', enabled => true);
    END;

在上面的代码中,我们创建了一个名为:job_name的job,它会在每天下午4点执行一次。其中,job_type是任务类型,job_action是任务执行的PL/SQL块,start_date是任务的启动时间,repeat_interval是任务的周期,enabled是任务是否启动。

  1. 查看job状态:

    SELECT job, state
    FROM dba_scheduler_jobs
    WHERE job_name = :job_name;

在上面的代码中,我们从dba_scheduler_jobs表中查询job的状态。其中,job是job的名称,state是job的状态。

  1. 取消job:

    BEGIN
    dbms_scheduler.drop_job (job_name => :job_name);
    END;

在上面的代码中,我们使用dbms_scheduler.drop_job方法来取消job。

  1. 更新job:

    BEGIN
    dbms_scheduler.alter_job (job_name => :job_name, repeat_interval => 'FREQ=DAILY; BYHOUR=12; BYMINUTE=00',
    start_date => sysdate, enabled => true);
    END;

在上面的代码中,我们使用dbms_scheduler.alter_job方法来更新job的周期、启动时间和是否启动。其中,repeat_interval是新的周期,start_date是新的启动时间,enabled是是否启动。

相关推荐
大熊猫侯佩40 分钟前
由一个 SwiftData “诡异”运行时崩溃而引发的钩深索隐(三)
数据库·swiftui·swift
大熊猫侯佩40 分钟前
由一个 SwiftData “诡异”运行时崩溃而引发的钩深索隐(二)
数据库·swiftui·swift
大熊猫侯佩1 小时前
用异步序列优雅的监听 SwiftData 2.0 中历史追踪记录(History Trace)的变化
数据库·swiftui·swift
大熊猫侯佩1 小时前
由一个 SwiftData “诡异”运行时崩溃而引发的钩深索隐(一)
数据库·swiftui·swift
Ares-Wang1 小时前
负载均衡LB》》HAproxy
运维·数据库·负载均衡
AI.NET 极客圈1 小时前
.NET 原生驾驭 AI 新基建实战系列(四):Qdrant ── 实时高效的向量搜索利器
数据库·人工智能·.net
weixin_470880262 小时前
MySQL体系架构解析(二):MySQL目录与启动配置全解析
数据库·mysql·面试·mysql体系架构·mysql bin目录
英英_2 小时前
MySQL 日志数据同步的详细教程
数据库·mysql
TDengine (老段)3 小时前
TDengine 替换 Hadoop,彻底解决数据丢失问题 !
大数据·数据库·hadoop·物联网·时序数据库·tdengine·涛思数据
南棱笑笑生3 小时前
20250605使用boot-repair来恢复WIN10和ubuntu22.04.6双系统的启动
数据库·postgresql