先看实例:
DECLARE
X NUMBER;
BEGIN
SYS.DBMS_JOB.SUBMIT( job => X,
what => 'ETL_Check_File;',
next_date => to_date('2009-08-26 01:00:00','yyyy-mm-dd hh24:mi:ss'),
interval => 'trunc(sysdate)+1+1/24',
no_parse => FALSE
);
SYS.DBMS_OUTPUT.PUT_LINE('Job Number is: ' || to_char(x));
COMMIT;
END;
以上是明确指定每天的1点执行此job,如果指定是每天中午12点执行interval需要指定为'trunc(sysdate)+1+12/24',如果仅仅指定interval为一天,这样当你手工用dbms_job.run(job)去运行一次时,job每天的执行时间是会改变的,如果你想job每天在固定时间执行,可以参考上面的例子.
初始化相关参数job_queue_processes
alter system set job_queue_processes=39 scope=spfile;//最大值不能超过1000
job_queue_interval = 10 //调度作业刷新频率秒为单位
job_queue_process 表示oracle能够并发的job的数量,可以通过语句
show parameter job_queue_process;
来查看oracle中job_queue_process的值。当job_queue_process值为0时表示全部停止oracle的job,可以通过语句
ALTER SYSTEM SET job_queue_processes = 10;
来调整启动oracle的job。
相关视图:
dba_jobs
all_jobs
user_jobs
dba_jobs_running 包含正在运行job相关信息
-------------------------
提交job语法:
begin
sys.dbms_job.submit(job => :job,
what => 'P_CLEAR_PACKBAL;',
next_date => to_date('04-08-2008 05:44:09', 'dd-mm-yyyy hh24:mi:ss'),
interval => 'sysdate+ 1/360');
commit;
end;
-------------------------
创建JOB
variable jobno number;
begin
dbms_job.submit(:jobno, 'P_CRED_PLAN;',SYSDATE,'SYSDATE+1/2880',TRUE);
commit;
运行JOB
SQL> begin
dbms_job.run(:job1);
end;
删除JOB
SQL> begin
dbms_job.remove(:job1);
end;
DBA_JOBS
===========================================
字段(列) 类型 描述
JOB NUMBER 任务的唯一标示号
LOG_USER VARCHAR2(30) 提交任务的用户
PRIV_USER VARCHAR2(30) 赋予任务权限的用户
SCHEMA_USER VARCHAR2(30) 对任务作语法分析的用户模式
LAST_DATE DATE 最后一次成功运行任务的时间
LAST_SEC VARCHAR2(8) 如HH24:MM:SS格式的last_date日期的小时,分钟和秒
THIS_DATE DATE 正在运行任务的开始时间,如果没有运行任务则为null
THIS_SEC VARCHAR2(8) 如HH24:MM:SS格式的this_date日期的小时,分钟和秒
NEXT_DATE DATE 下一次定时运行任务的时间
NEXT_SEC VARCHAR2(8) 如HH24:MM:SS格式的next_date日期的小时,分钟和秒
TOTAL_TIME NUMBER 该任务运行所需要的总时间,单位为秒
BROKEN VARCHAR2(1) 标志参数,Y标示任务中断,以后不会运行
INTERVAL VARCHAR2(200) 用于计算下一运行时间的表达式
FAILURES NUMBER 任务运行连续没有成功的次数
WHAT VARCHAR2(2000) 执行任务的PL/SQL块
CURRENT_SESSION_LABEL RAW MLSLABEL 该任务的信任Oracle会话符
CLEARANCE_HI RAW MLSLABEL 该任务可信任的Oracle最大间隙
CLEARANCE_LO RAW MLSLABEL 该任务可信任的Oracle最小间隙
NLS_ENV VARCHAR2(2000) 任务运行的NLS会话设置
MISC_ENV RAW(32) 任务运行的其他一些会话参数
--------------------------
描述 INTERVAL参数值
每天午夜12点 'TRUNC(SYSDATE + 1)'
每天早上8点30分 'TRUNC(SYSDATE + 1) + (8*60+30)/(24*60)'
每星期二中午12点 'NEXT_DAY(TRUNC(SYSDATE ), ''TUESDAY'' ) + 12/24'
每个月第一天的午夜12点 'TRUNC(LAST_DAY(SYSDATE ) + 1)'
每个季度最后一天的晚上11点 'TRUNC(ADD_MONTHS(SYSDATE + 2/24, 3 ), 'Q' ) -1/24'
每星期六和日早上6点10分 'TRUNC(LEAST(NEXT_DAY(SYSDATE, ''SATURDAY"), NEXT_DAY(SYSDATE, "SUNDAY"))) + (6×60+10)/(24×60)'
--------------------------
1:每分钟执行
Interval => TRUNC(sysdate,'mi') + 1/ (24*60)
或
Interval => sysdate+1/1440
2:每天定时执行
例如:每天的凌晨1点执行
Interval => TRUNC(sysdate) + 1 +1/ (24)
3:每周定时执行
例如:每周一凌晨1点执行
Interval => TRUNC(next_day(sysdate,'星期一'))+1/24
4:每月定时执行
例如:每月1日凌晨1点执行
Interval =>TRUNC(LAST_DAY(SYSDATE))+1+1/24
5:每季度定时执行
例如每季度的第一天凌晨1点执行
Interval => TRUNC(ADD_MONTHS(SYSDATE,3),'Q') + 1/24
6:每半年定时执行
例如:每年7月1日和1月1日凌晨1点
Interval => ADD_MONTHS(trunc(sysdate,'yyyy'),6)+1/24
7:每年定时执行
例如:每年1月1日凌晨1点执行
Interval =>ADD_MONTHS(trunc(sysdate,'yyyy'),12)+1/24
分享到:
相关推荐
以下是对标题和描述中涉及的Oracle数据库管理知识点的详细说明: 1. **系统安装**:在安装Oracle数据库时,需要考虑硬件配置、操作系统兼容性、网络环境等因素。错误可能包括磁盘空间不足、依赖库缺失、权限问题等...
### Oracle数据库整理学习手册知识点详解 #### 一、Oracle数据库简介 Oracle数据库是由甲骨文公司(Oracle Corporation)开发的一款关系型数据库管理系统。甲骨文公司作为全球知名的软件服务商之一,在数据库市场上...
从给定的文件信息来看,这是一份关于Oracle数据库基础知识的学习笔记,由李兴华整理。下面将根据标题、描述以及部分摘录的内容,详细展开其中包含的关键知识点。 ### Oracle数据库简介 Oracle是由美国甲骨文公司...
从给定的Oracle自学笔记和视频实例整理的内容中,我们可以提炼出一系列关于SQL查询和数据操作的重要知识点。以下是对这些知识点的详细解析: ### 1. 基本的SELECT语句 - **获取所有列**:`SELECT * FROM emp;` 这是...
根据提供的文件信息,我们可以整理出关于Oracle简单查找技术的相关知识点,包括字符串函数、日期函数以及基本的查询技术等。下面将对这些知识点进行详细的说明。 ### Oracle简单查找知识总结 #### 1. 基本SQL语法...
根据提供的文件信息,我们可以归纳出以下Oracle数据库的相关知识点: ### 一、创建表 #### 1. 使用子查询创建表 - **语法**: `CREATE TABLE new_table_name AS SELECT * FROM existing_table WHERE condition;` - *...
### Oracle管理及优化知识点 #### 一、SQL优化原则与实践 ##### 1. 尽量减少使用 IN - **原因分析**:使用`IN`会导致数据库无法有效地利用索引,尤其是在`IN`后面的列表非常长的情况下,可能导致性能显著下降。 -...
知识点:The Job Queue Processes 是 Oracle 数据库中的一种后台进程,用于刷新 materialized view。 11. 如何判断哪个 session 正在连接以及他们等待的资源? 答案:V$SESSION /V$SESSION_WAIT 知识点:V$SESSION ...
根据提供的标题、描述、标签及部分内容,我们可以整理出与Oracle PL/SQL相关的多个知识点,具体包括以下几个方面: ### Oracle PL/SQL 基础 **标题:** Oracle PL/SQL语句大全 **描述:** Oracle PL/SQL是Oracle...
根据提供的信息,我们可以总结出以下关于Oracle数据库的关键...以上就是根据给定的文件信息整理出的主要知识点。通过这些内容的学习,可以更加深入地理解Oracle数据库中的查询技巧和方法,有助于提高数据处理的能力。
### Oracle数据库日常维护方案知识点详解 #### 一、项目背景及目标 - **项目背景**:随着企业信息化建设的不断推进和发展,当前已有成熟稳定的网络环境以及覆盖生产经营管理的多种应用系统。面对超过600台在线运行...
在Oracle数据库环境中,DBJob(数据库作业)与操作系统的计划任务有着异曲同工之妙。DBJob允许用户在特定时间段内安排和执行存储过程。然而,操作系统计划任务往往无法胜任数据库特定任务,特别是在数据库可能处于非...
### Toad for Oracle 使用手册关键知识点总结 #### 一、简介与新特性 - **Toad for Oracle**:是一款强大的数据库开发与管理工具,适用于Oracle数据库环境。 - **新版本特性**:概述了Toad for Oracle最新版本的...
这份文档由魔乐科技的李兴华老师整理,通过图文并茂的形式帮助读者更好地理解和掌握Oracle 10g的相关知识。 ### Oracle 数据库简介 Oracle是由Larry Ellison于1977年创立的Oracle公司所开发的一款数据库管理系统。...
以上就是基于提供的文件内容整理的Oracle操作语句的详细介绍,涵盖了表结构描述、基础查询、数据选择与处理、字符串操作、去重查询、条件查询、区间与集合查询、日期查询、逻辑运算符、通配符查询和排序等方面的知识...
以下是根据教程内容整理出的关键知识点: 一、Oracle简介 Oracle数据库是由美国Oracle公司开发的,支持多种操作系统平台,具有高可用性、高性能和可扩展性的特点。其数据模型基于SQL(结构化查询语言),提供了丰富...
### 数据库基础知识精讲 #### 一、数据库与表的基本操作 在数据库管理中,创建、更新、...这些知识点不仅适用于Oracle数据库,同样适用于MySQL等其他数据库系统。掌握这些内容对于数据库开发人员来说是非常重要的。
根据提供的文件信息,我们可以归纳总结出Oracle数据库相关...以上是基于给定的文件信息整理出的Oracle数据库相关的知识点及其具体应用场景。通过这些示例,我们可以更深入地理解Oracle数据库的基本操作和高级查询技巧。
根据提供的文件信息,我们可以归纳和整理出以下几个关键的Oracle SQL知识点: ### 多表查询基本概念及语法 #### 1. 多表查询定义 - **定义**:当需要从两个或两个以上的表中获取数据时,即为多表查询。 #### 2. ...
根据提供的文件信息,我们可以整理出一系列关于Oracle数据库的关键知识点,主要涵盖了从基本操作到更高级功能的应用。下面将对这些知识点进行详细的解释和说明。 ### 一、查询语句示例 #### 1. 使用GROUP BY子句...