前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >ORACLE中JOB的使用

ORACLE中JOB的使用

作者头像
小小明童鞋
发布2018-06-13 16:23:24
8220
发布2018-06-13 16:23:24
举报
文章被收录于专栏:java系列博客java系列博客

JOB:和JAVA中的job类似,都是定时任务。

首先,建表:

代码语言:javascript
复制
-- Create table
create table MYDAILYDK
(
  ID     NUMBER(19) not null,
  NAME   VARCHAR2(255),
  DKTIME DATE
)
tablespace NG_DATA
  pctfree 10
  initrans 1
  maxtrans 255
  storage
  (
    initial 64K
    next 1M
    minextents 1
    maxextents unlimited
  );

然后,建个存储过程,用来向表里插入数据:

代码语言:javascript
复制
create or replace procedure mbproc_mydailydk

as

begin

insert into mydailydk(id,name,dktime)
values(s_madailydk.nextval,'小明',sysdate);
commit;

end;

JOB参数简介:

/**    job参数是由Submit()过程返回的binary_ineger。这个值用来唯一标识一个工作。      what参数是将被执行的PL/SQL代码块。      next_date参数指识何时将运行这个工作。      interval参数何时这个工作将被重执行。      no_parse参数指示此工作在提交时或执行时是否应进行语法分析——TRUE      指示此PL/SQL代码在它第一次执行时应进行语法分析,      而FALSE指示本PL/SQL代码应立即进行语法分析。     */

创建JOB:

代码语言:javascript
复制
begin
  sys.dbms_job.submit(job => :job,
                      what => 'mbproc_mydailydk;',
                      next_date => to_date('08-11-2016 14:22:08', 'dd-mm-yyyy hh24:mi:ss'),
                      interval => 'sysdate+1');
  commit;
end;

说明:ORACLE会自动生成唯一的JOB标识,就是submit的第一个参数。

查看创建的job:

代码语言:javascript
复制
     select * from user_jobs;

手动运行Job,参数为自动生成的唯一标识,我的是64,把:job换成64即可,由于我的开始时间是sysdate,手动每天的这个时候去执行一次,因此查看存储过程中插入的表会有一条数据插入:

代码语言:javascript
复制
  begin
  dbms_job.run(:job);
  end;

查看被插入的表:

代码语言:javascript
复制
     select * from mydailydk;

停止job:

代码语言:javascript
复制
  begin
     
       dbms_job.broken(64, true);
     
  end;

删除job:

代码语言:javascript
复制
  begin
     
       dbms_job.remove(64);
     
  end;

另外,关于 dbms_job 这个pakage中的其它函数请自行查阅:change()、Interval()、Isubmit()、Next_Date()等等。

附上pakage的文档的连接:

https://docs.oracle.com/cd/B19306_01/appdev.102/b14258/d_job.htm#i1000681

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
对象存储
对象存储(Cloud Object Storage,COS)是由腾讯云推出的无目录层次结构、无数据格式限制,可容纳海量数据且支持 HTTP/HTTPS 协议访问的分布式存储服务。腾讯云 COS 的存储桶空间无容量上限,无需分区管理,适用于 CDN 数据分发、数据万象处理或大数据计算与分析的数据湖等多种场景。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档