oracle定时任务指定id,oracle数据库定时任务_摆渡仁的博客-程序员宅基地

技术标签: oracle定时任务指定id  

常要Oracle数据库定时的自动执行一些脚本,或做数据库备份,或做数据的提炼,或做数据库的性能优化,包括重建索引等等的工作,这时需要用到一个函数dbms_job.submit,来完成oracle定时器Job时间的处理上。使用dbms_job.submit这个函数,我们只需要考虑两个事情:安排某一任务,和定制一个执行任务的时间点。但最重要也是最棘手的事情,我认为还是确定一个执行任务的时间点。时间点确定了,其他的事情就好办了。下面是函数dbms_job.submit使用方法:

Java代码

dbms_job.submit(joboutbinary_integer,

what       in   archar2,

next_date    in   date,

interval     in   varchar2,248); line-height:18px; margin:0px!important; padding:0px 3px 0px 10px!important; list-style-position:outside!important"> no_parse     inboolean)

其中:

●job:输出变量,是此任务在任务队列中的编号;

●what:执行的任务的名称及其输入参数;

●next_date:任务执行的时间;

●interval:任务执行的时间间隔。

其中Interval这个值是决定Job何时,被重新执行的关键;当interval设置为null时,该job执行结束后,就被从队列中删除。假如我们需要该job周期性地执行,则要用‘sysdate+m’表示。如何更好地确定执行时间的间隔需要我们掌握一个函数TRUNC。

1.TRUNC(for dates)

TRUNC函数为指定元素而截去的日期值。

其具体的语法格式如下:

TRUNC(date[,fmt])

其中:

date 一个日期值

fmt 日期格式,该日期将由指定的元素格式所截去。忽略它则由最近的日期截去

下面是该函数的使用情况:

1)按年截尾

select TRUNC(TO_DATE('2008-03-01 08:23','yyyy-mm-dd hh:mi'),'yyyy') from dual

-----------------------------------------------------------

2008-1-1

2)按月截尾

select TRUNC(TO_DATE('2008-03-01 08:23','mm') from dual

--------------------------------------------------------

2008-3-1

3)按日截尾

select TRUNC(TO_DATE('2008-03-01 08:23','dd') from dual

----------------------------------------------------------------------

2008-3-1

4)按时截尾

select TRUNC(TO_DATE('2008-03-01 08:23','hh') from dual

----------------------------------------------------------------------

2008-3-1 8:00:00

5)按分截尾

select TRUNC(TO_DATE('2008-03-01 08:23','mi') from dual

----------------------------------------------------------------------

2008-3-1 8:23:00

2.确定执行时间间隔

1)、 每分钟执行

Interval => TRUNC(sysdate,'mi') + 1 / (24*60)

2)、 每天定时执行

例如:每天的凌晨2点执行

Interval => TRUNC(sysdate) + 1 +2 / (24)

3)、 每周定时执行

例如:每周一凌晨2点执行

Interval => TRUNC(next_day(sysdate,2))+2/24 --星期一,一周的第二天

4)、 每月定时执行

例如:每月1日凌晨2点执行

Interval =>TRUNC(LAST_DAY(SYSDATE))+1+2/24

5)、 每季度定时执行

例如每季度的第一天凌晨2点执行

Interval => TRUNC(ADD_MONTHS(SYSDATE,3),'Q') + 2/24

6)、 每半年定时执行

例如:每年7月1日和1月1日凌晨2点

Interval => ADD_MONTHS(trunc(sysdate,'yyyy'),6)+2/24

7)、 每年定时执行

例如:每年1月1日凌晨2点执行

Interval =>ADD_MONTHS(trunc(sysdate,12)+2/24

3.实例

这里提供了一个简单的例子,主要是完成在每一个时间间隔内向一个表中插入一条记录

1)创建测试表 、序列

sql>createtabletest(idnumber,cur_timedate);

表已创建。

----建sequence

CREATESEQUENCEtest_sequence

INCREMENTBY1--每次加几个

STARTWITH1--从1开始计数

NOMAXVALUE   --不设置最大值

NOCYCLE     --一直累加,不循环

CACHE10;

--建触发器代码为:

createorreplacetriggertri_test_id

beforeinsertontest--test是表名

foreachrow

declare

nextidnumber;

begin

IF:new.idISNULLor:new.id=0THEN--id是列名

selecttest_sequence.nextval--SEQ_ID正是刚才创建的

intonextid

fromsys.dual;

:new.id:=nextid;

endif;

endtri_test_id;

2)创建一个自定义过程

sql>createorreplaceprocedureproc_testas

2begin

3insertintotest(cur_time)values(sysdate);

4end;

5/

过程已创建。

3)创建JOB

sql>declarejob1number;

dbms_job.submit(job1,'proc_test;',sysdate,'sysdate+1/1440');--每天1440分钟,即一分钟运行test过程一次

end;

PL/sql JOB已成功完成。

总结

以上是编程之家为你收集整理的oracle数据库定时任务全部内容,希望文章能够帮你解决oracle数据库定时任务所遇到的程序开发问题。

如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_35203962/article/details/116320836

智能推荐

职业发展的困境-程序员宅基地

作者:白色蜗牛公众号:蜗牛互联网三年前,我还是一个职场小白。对技术体系不懂,对业务流程不懂,对沟通协作不懂。好在有贵人相助,印象深刻的是三个师兄,他们各有特点,一直以来在不同的方面引导我...

双机热备Nginx+Keepalived搭建HA高可用负载均衡环境-程序员宅基地

一张简单的图说下大概的意思安装Keepalived到CentOS虚拟机环境(2个虚拟机都安装) 使用的版本为keepalived-1.2.24.tar.gz 为了方便安装,在系统里面提前下载好相关的库yum -y install libnl libnl-develyum install -y libnfnetlink-devel然后就开始解压编译安装吧_双机热备nginx

vue专栏 05.vue高阶API 05.高阶其他 03.全局钩子新用法_全栈开发的博客-程序员宅基地

# 03.全局钩子新用法[toc]{type: "ol", level: [3,4]}### 关系映射> 选项API生命周期与组合式API之间的映射- beforeCreate --> use setup- created --> use setup- beforeMount --> onBeforeMount- mounted --> onMounted- ... (...

基于iText和flying saucer结合freemark java生成pdf 范例-程序员宅基地

2019独角兽企业重金招聘Python工程师标准>>> ...

android一键 iphone,安卓手机一键变“iPhone”,这种App太过分了_不期风吟的博客-程序员宅基地

原标题:安卓手机一键变“iPhone”,这种App太过分了最近有小伙伴问小雷,如何才能在安卓手机上使用iOS的桌面。让整个手机看起来更加清爽整洁。想让苹果手机变得“卓里卓气”可能有点麻烦,但是如果是安卓手机想变成iOS风格,那是分分钟就能搞定的事情。今天小雷就给大家推荐一款能够随意更换主题UI的实用软件——【X Launcher Pro】。这是一款模仿iPhone手机界面的应用,有了它可以让手机界..._安卓模拟苹果系统

随便推点

ExtJs_ExtContainer解说-程序员宅基地

/* * Ext JS Library 3.3.0 *//** * @class Ext.Container * @extends Ext.BoxComponent * * Base class for any {Ext.BoxComponent} that may conta

jquery Easyui 大数据的处理-利用scrollview进行数据展示。_easyui scrollview-程序员宅基地

需求:当初不想用分页查询数据,然后就找有那些可以代替传统的Pagination分页的方法,然后发现了scrollview这个控件方法,发现挺好用的就分享一下,我的案例。首先我们在html页面引入jQueryeasyui的类库和datagrid-scrollview.js。 <script type="text/javascript" src="https://www.jeas..._easyui scrollview

理解javascript的闭包,原型,和匿名函数及IIFE-程序员宅基地

理解javascript的闭包,原型,和匿名函数(自己总结)一 .>关于闭包理解闭包 需要的知识1.变量的作用域例1:var n =99; //建立函数外的全局变量function readA(){ alert(n); //读取全局变量}readA(); //执行此函数例2:function readB(){ var c =..._iife 和 匿名函数

静态NAT、动态NAT-程序员宅基地

静态NAT、动态NAT实验拓扑:实验目的:熟悉网络地址转换协议掌握静态NAT 和动态NAT的配置分析静态NAT 和动态NAT的区别使用show命令来检查NAT的运行情况实验要求:按拓扑图来配置静态NAT 和动态NAT实验步骤:步骤1 按如上拓扑做好底层配置,并检验相邻设备之间的连通性步骤2在NAT 上配置一条到internet的缺省路由NAT(conf...

secureCRT常用设置-程序员宅基地

一、快捷键:1、 ctrl + a : 移动光标到行首【常用】2、 ctrl + e :移动光标到行尾【常用】3、 ctrl + d :删除光标之后的一个字符4、 ctrl + w : 删除行首到当前光标所在位置的所有字符【常用】5、 crtl + k : 删除当前光标到行尾的所有字符【常用】6、 alt + b : 打开快速启动栏7、 alt + 1/2/3… : 在多个不同的se...