oracle dbms_job 写法

2024-02-16 15:20
文章标签 oracle 写法 job dbms

本文主要是介绍oracle dbms_job 写法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

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

  1. 创建job:
BEGINdbms_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点开始执行,并以一天为周期进行。
2. 查看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的状态。
3. 取消job:

BEGINdbms_job.remove(job => :job_name);
END;

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

BEGINdbms_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:
BEGINdbms_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是任务是否启动。
2. 查看job状态:

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

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

BEGINdbms_scheduler.drop_job (job_name => :job_name);
END;

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

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

这篇关于oracle dbms_job 写法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/714942

相关文章

MySQL中删除重复数据SQL的三种写法

《MySQL中删除重复数据SQL的三种写法》:本文主要介绍MySQL中删除重复数据SQL的三种写法,文中通过代码示例讲解的非常详细,对大家的学习或工作有一定的帮助,需要的朋友可以参考下... 目录方法一:使用 left join + 子查询删除重复数据(推荐)方法二:创建临时表(需分多步执行,逻辑清晰,但会

Oracle的to_date()函数详解

《Oracle的to_date()函数详解》Oracle的to_date()函数用于日期格式转换,需要注意Oracle中不区分大小写的MM和mm格式代码,应使用mi代替分钟,此外,Oracle还支持毫... 目录oracle的to_date()函数一.在使用Oracle的to_date函数来做日期转换二.日

oracle数据库索引失效的问题及解决

《oracle数据库索引失效的问题及解决》本文总结了在Oracle数据库中索引失效的一些常见场景,包括使用isnull、isnotnull、!=、、、函数处理、like前置%查询以及范围索引和等值索引... 目录oracle数据库索引失效问题场景环境索引失效情况及验证结论一结论二结论三结论四结论五总结ora

springboot整合 xxl-job及使用步骤

《springboot整合xxl-job及使用步骤》XXL-JOB是一个分布式任务调度平台,用于解决分布式系统中的任务调度和管理问题,文章详细介绍了XXL-JOB的架构,包括调度中心、执行器和Web... 目录一、xxl-job是什么二、使用步骤1. 下载并运行管理端代码2. 访问管理页面,确认是否启动成功

Oracle Expdp按条件导出指定表数据的方法实例

《OracleExpdp按条件导出指定表数据的方法实例》:本文主要介绍Oracle的expdp数据泵方式导出特定机构和时间范围的数据,并通过parfile文件进行条件限制和配置,文中通过代码介绍... 目录1.场景描述 2.方案分析3.实验验证 3.1 parfile文件3.2 expdp命令导出4.总结

Oracle数据库执行计划的查看与分析技巧

《Oracle数据库执行计划的查看与分析技巧》在Oracle数据库中,执行计划能够帮助我们深入了解SQL语句在数据库内部的执行细节,进而优化查询性能、提升系统效率,执行计划是Oracle数据库优化器为... 目录一、什么是执行计划二、查看执行计划的方法(一)使用 EXPLAIN PLAN 命令(二)通过 S

Codeforces Beta Round #47 C凸包 (最终写法)

题意慢慢看。 typedef long long LL ;int cmp(double x){if(fabs(x) < 1e-8) return 0 ;return x > 0 ? 1 : -1 ;}struct point{double x , y ;point(){}point(double _x , double _y):x(_x) , y(_y){}point op

Oracle type (自定义类型的使用)

oracle - type   type定义: oracle中自定义数据类型 oracle中有基本的数据类型,如number,varchar2,date,numeric,float....但有时候我们需要特殊的格式, 如将name定义为(firstname,lastname)的形式,我们想把这个作为一个表的一列看待,这时候就要我们自己定义一个数据类型 格式 :create or repla

ORACLE 11g 创建数据库时 Enterprise Manager配置失败的解决办法 无法打开OEM的解决办法

在win7 64位系统下安装oracle11g,在使用Database configuration Assistant创建数据库时,在创建到85%的时候报错,错误如下: 解决办法: 在listener.ora中增加对BlueAeri-PC或ip地址的侦听,具体步骤如下: 1.启动Net Manager,在“监听程序”--Listener下添加一个地址,主机名写计

Oracle Start With关键字

Oracle Start With关键字 前言 旨在记录一些Oracle使用中遇到的各种各样的问题. 同时希望能帮到和我遇到同样问题的人. Start With (树查询) 问题描述: 在数据库中, 有一种比较常见得 设计模式, 层级结构 设计模式, 具体到 Oracle table中, 字段特点如下: ID, DSC, PID; 三个字段, 分别表示 当前标识的 ID(主键), DSC 当