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是是否启动。

相关推荐
l1t1 小时前
用parser_tools插件来解析SQL语句
数据库·sql·插件·duckdb
代码程序猿RIP1 小时前
【SQLite 库】sqlite3_open_v2
jvm·oracle·sqlite
TDengine (老段)1 小时前
TDengine 数学函数 ABS() 用户手册
大数据·数据库·sql·物联网·时序数据库·tdengine·涛思数据
lypzcgf1 小时前
Coze源码分析-资源库-编辑数据库-后端源码-安全与错误处理
数据库·安全·系统架构·coze·coze源码分析·ai应用平台·agent平台
阿湯哥1 小时前
Redis数据库隔离业务缓存对查询性能的影响分析
数据库·redis·缓存
麦兜*1 小时前
Redis 7.2 新特性实战:Client-Side Caching(客户端缓存)如何大幅降低延迟?
数据库·spring boot·redis·spring·spring cloud·缓存·tomcat
web安全工具库1 小时前
Linux 高手进阶:Vim 核心模式与分屏操作详解
linux·运维·服务器·前端·数据库
月起星九2 小时前
为什么ffmpeg进行视频合成有时长误差
ffmpeg·音视频