【JOB】Oracle中JOB的创建方法以及一个细节的探究

在Oracle中可以使用JOB来实现一些任务的自动化执行,类似于UNIX操作系统crontab命令的功能。
简单演示一下,供参考。

1.创建表T,包含一个X字段,定义为日期类型,方便后面的定时任务测试。
[email protected]ora10g> create table t (x date);

Table created.

2.创建存储过程p_insert_into_t,每次执行该存储过程都会向T表中插入一条系统当前时间。
[email protected]ora10g> create or replace procedure
p_insert_into_t
2 as
3
begin
4 insert into t
5
values (SYSDATE);
6 end;
7
/

Procedure created.

3.OK,准备就绪,我们来创建一个JOB,这个JOB会每分钟运行一次?需要注意一个细节!
[email protected]ora10g> variable job_number number;
[email protected]ora10g> begin
2
DBMS_JOB.submit (:job_number,
3
‘P_INSERT_INTO_T;‘,
4 SYSDATE,

5 ‘sysdate+1/(24*60)‘);
6
end;
7 /

PL/SQL procedure successfully
completed.

4.我们通过USER_JOBS视图查看一下创建的JOB信息。
[email protected]ora10g> select job,

2 log_user,
3 to_char(last_date,‘yyyy-mm-dd
hh24:mi:ss‘) last_date,
4 to_char(next_date,‘yyyy-mm-dd
hh24:mi:ss‘) next_date,
5 interval,

6 what
7 from user_jobs
8
/

JOB LOG_USER LAST_DATE
NEXT_DATE INTERVAL WHAT
-------
-------- ------------------- ------------------- -----------------
----------------
27 SEC 2010-01-29
00:34:20 sysdate+1/(24*60) P_INSERT_INTO_T;

细节之处在此,此处的LAST_DATE内容是空,表示此JOB没有被执行过,因此这个JOB将永远不会被自动的执行。
这一点可以从T表没有数据来得到验证:
[email protected]ora10g> select * from t;

no rows selected

那么,如何才能使它自动执行起来呢?
很简单,只要我们手动将这个JOB执行一下即可。

5.手工执行JOB一次,使之按照既定的时间间隔执行。
[email protected]ora10g> execute dbms_job.run(27);

PL/SQL procedure successfully
completed.

此时T表中将会被插入一条具有当前时间的数据。
[email protected]ora10g> select * from t;

X
-------------------
2010-01-29 00:37:42

再次查看JOB的信息
[email protected]ora10g> select job,

2 log_user,
3 to_char(last_date,‘yyyy-mm-dd
hh24:mi:ss‘) last_date,
4 to_char(next_date,‘yyyy-mm-dd
hh24:mi:ss‘) next_date,
5 interval,

6 what
7 from user_jobs
8
/

JOB LOG_USER LAST_DATE
NEXT_DATE INTERVAL WHAT
-------
-------- ------------------- ------------------- -----------------
----------------
27 SEC 2010-01-29 00:37:42 2010-01-29
00:38:42 sysdate+1/(24*60) P_INSERT_INTO_T;

此时LAST_DATE显示了我们执行JOB的时间,同时NEXT_DATE显示了下次JOB将被执行的时间。此后这个JOB将会每隔一分钟被执行一次。
自动执行一段时间后的T表内容如下:
[email protected]ora10g> select * from t order by x;

X
-------------------
2010-01-29 00:37:42
2010-01-29 00:38:46
2010-01-29 00:39:46
2010-01-29 00:40:46
2010-01-29 00:41:46
2010-01-29 00:42:46
2010-01-29 00:43:46
2010-01-29 00:44:46
2010-01-29 00:45:46
2010-01-29 00:46:46
2010-01-29 00:47:46
2010-01-29 00:48:46
2010-01-29 00:49:46
2010-01-29 00:50:46
2010-01-29 00:51:46
2010-01-29 00:52:46

16 rows selected.

6.为什么刚刚创建后的JOB不能自动的执行呢?
这是一个疏忽导致的!
在创建JOB的时候,需要在结尾处指定“COMMIT;”!表示创建完成之后便执行一次。
删除之前的JOB,重新创建一个带有“COMMIT”语句的新JOB。
[email protected]ora10g> variable job_number number;
[email protected]ora10g> begin
2
DBMS_JOB.submit (:job_number,
3
‘P_INSERT_INTO_T;‘,
4 SYSDATE,

5 ‘sysdate+1/(24*60)‘);
6
commit;
7 end;
8
/

[email protected]> print job_number;

JOB_NUMBER
----------

29

此次创建的JOB信息如下,可见LAST_DATE在创建完之后便有内容,表示已经被执行了一次。
[email protected]ora10g> select job,

2 log_user,
3 to_char(last_date,‘yyyy-mm-dd
hh24:mi:ss‘) last_date,
4 to_char(next_date,‘yyyy-mm-dd
hh24:mi:ss‘) next_date,
5 interval,

6 what
7 from user_jobs
8
/

JOB LOG_USER LAST_DATE
NEXT_DATE INTERVAL WHAT
-------
-------- ------------------- ------------------- -----------------
----------------
29 SEC 2010-01-29 01:02:11 2010-01-29
01:03:11 sysdate+1/(24*60) P_INSERT_INTO_T;

一分钟过后便可看到T表中已有两条记录。
[email protected]ora10g> select * from t;

X
-------------------
2010-01-29 01:02:11
2010-01-29 01:03:11

7.删除JOB方法
很简单,使用“dbms_job.remove”即可。
[email protected]ora10g> execute dbms_job.remove(29);

PL/SQL procedure successfully
completed.

8.最后,谈一下创建JOB时用到的参数。
1)使用desc命令查看DBMS_JOB,可以得到SUBMIT这个存储过程的参数列表。
[email protected]ora10g> desc DBMS_JOB
...
PROCEDURE SUBMIT
Argument Name
Type In/Out Default?
------------------------------
----------------------- ------ --------
JOB
BINARY_INTEGER OUT
WHAT
VARCHAR2 IN
NEXT_DATE
DATE IN DEFAULT
INTERVAL
VARCHAR2 IN DEFAULT
NO_PARSE
BOOLEAN IN DEFAULT
INSTANCE
BINARY_INTEGER IN DEFAULT
FORCE
BOOLEAN IN DEFAULT
...

2)如果希望对这些参数有更好的理解,可以参考Oracle的官方文档描述,细致而周到。
http://download.oracle.com/docs/cd/B19306_01/appdev.102/b14258/d_job.htm#sthref2936

3)重点关注一下官方文档中关于INTERVAL参数的示例
‘sysdate
+ 7‘表示一周执行一次;
‘next_day(sysdate,‘‘TUESDAY‘‘)‘
表示每周二执行一次;
‘null‘表示只执行一次。

本文中我使用的是‘sysdate+1/(24*60)‘表示每分钟执行一次。很形象,一天的二十四分之一是一小时,一小时的六十分之一就是一分钟的意思。

9.小结
通过这个文章和大家分享了一点关于JOB的创建方法和使用,希望对大家有帮助。
细节不容错过!

Good luck.

secooler
10.01.28

-- The End --

时间: 2024-08-10 02:53:57

【JOB】Oracle中JOB的创建方法以及一个细节的探究的相关文章

Oracle中生成uuid的方法

Oracle中生成uuid的方法 下载LOFTER客户端 在Oracle SQL 提供了一个生成uuid的函数sys_guid: http://download.oracle.com/docs/cd/E11882_01/server.112/e17118/functions187.htm#i79194 http://en.wikipedia.org/wiki/Universally_unique_identifier SQL> select sys_guid() from dual ; SYS_

在第一战中,我们创建了第一个App project

前情提要(Previously) 在第一战中,我们创建了第一个App project, Hello World,并分析了项目结构,及运行原理. 链接在此:Android Studio 单刷<第一行代码>系列 01 —— 第一战 HelloWorld 摘要(Abstract) 必备技能,使用日志工具 LogCat,并尝试解决真机调试没有日志的问题. 日志工具(LogCat) 日志在任何项目的开发过程中都会起到非常重要的作用,在 Android 项目中如果你想要查看日志则必须要使用 LogCat

Oracle自增列创建方法

最近在做Oracle的项目,由于以前没有接触过Oracle的开发,遇到了不少的问题,比如给Oracle表添加自增列,与SQL Server就不同. Oracle没有自增字段这样的功能,但是通过触发器(trigger)和序列(sequence)可以实现. 先建一个测试表了: create table userlogin( id   number(6) not null, name   varchar2(30)   not null primary key ) tablespace users /

[转] - Oracle 中 EXP / IMP 使用方法

Exp/Imp是oracle备份数据的两个命令行工具 1.本地数据库导入导出 1.导出 (运行---cmd中操作) exp 用户名/密码@数据库实例名file=本地存放路径 eg: exp jnjp/[email protected] file=C:/jnjp.dmp 2.导入 imp 用户名/密码@数据库实例名file=本地数据库文件存放路径full=y   ignore=y eg: imp jnjp/[email protected]  file=E:\jnjp.dmp  full=y  i

oracle中一些用法与方法区分

1. case用法: --简单case函数 case sex when '1' then 'boy' when '2' then 'girl' else '其他' end; --case搜索函数 case when sex ='1' then 'boy' when sex ='2' then 'girl' else '其他' end; 举例:判断工资等级,统计每个等级的人数, SELECT CASE WHEN salary <= 500 THEN '1' WHEN salary > 500 A

JS中数组的创建方法

<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <title></title> <script type="text/javascript"> /** * * js数组可以存储任意类型的数据 类似于java中的List<Object> * 声明数组 * 第一种 通过Array对象

Oracle中包的创建

包是过程和函数的集合体,包包括创建包和创建包体,创建包的时候在可以定义过程和函数,包体中则具体实现过程和函数. eg: --创建包 create  or replace package mypac1 is procedure mypro1(p_ename varchar2,p_sal number); function myfun1(f_ename varxhar2) return number; end; --创建包体 create package body mypac1 is procedu

Oracle中sequence的使用方法

在Oracle数据库中,sequence等同于序列号,每次取的时候sequence会自动增加,一般会作用于需要按序列号排序的地方. 1.Create Sequence (注释:你需要有CREATE SEQUENCE或CREATE ANY SEQUENCE权限) CREATE SEQUENCE emp_sequence INCREMENT BY 1 —— 每次加几个 START WITH 1 —— 从1开始计数 NOMAXVALUE —— 不设置最大值 NOCYCLE —— 一直累加,不循环 CA

Oracle中dblink的创建与删除

查询数据库中有哪些dblink连接 select * from dba_objects where object_type='DATABASE LINK'; 删除公有的EMIS_PRODUCTOIN连接 drop public database link EMIS_PRODUCTION; 创建公有的EMIS_PRODUCTION连接 create public database link EMIS_PRODUCTION connect to EMIS_FRAME identified by EM