技术标签: 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数据库定时任务所遇到的程序开发问题。
如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
net core 6.0 +vue尝试一_vue .net core
作者:白色蜗牛公众号:蜗牛互联网三年前,我还是一个职场小白。对技术体系不懂,对业务流程不懂,对沟通协作不懂。好在有贵人相助,印象深刻的是三个师兄,他们各有特点,一直以来在不同的方面引导我...
一张简单的图说下大概的意思安装Keepalived到CentOS虚拟机环境(2个虚拟机都安装) 使用的版本为keepalived-1.2.24.tar.gz 为了方便安装,在系统里面提前下载好相关的库yum -y install libnl libnl-develyum install -y libnfnetlink-devel然后就开始解压编译安装吧_双机热备nginx
# 03.全局钩子新用法[toc]{type: "ol", level: [3,4]}### 关系映射> 选项API生命周期与组合式API之间的映射- beforeCreate --> use setup- created --> use setup- beforeMount --> onBeforeMount- mounted --> onMounted- ... (...
2019独角兽企业重金招聘Python工程师标准>>> ...
原标题:安卓手机一键变“iPhone”,这种App太过分了最近有小伙伴问小雷,如何才能在安卓手机上使用iOS的桌面。让整个手机看起来更加清爽整洁。想让苹果手机变得“卓里卓气”可能有点麻烦,但是如果是安卓手机想变成iOS风格,那是分分钟就能搞定的事情。今天小雷就给大家推荐一款能够随意更换主题UI的实用软件——【X Launcher Pro】。这是一款模仿iPhone手机界面的应用,有了它可以让手机界..._安卓模拟苹果系统
/* * Ext JS Library 3.3.0 *//** * @class Ext.Container * @extends Ext.BoxComponent * * Base class for any {Ext.BoxComponent} that may conta
需求:当初不想用分页查询数据,然后就找有那些可以代替传统的Pagination分页的方法,然后发现了scrollview这个控件方法,发现挺好用的就分享一下,我的案例。首先我们在html页面引入jQueryeasyui的类库和datagrid-scrollview.js。 <script type="text/javascript" src="https://www.jeas..._easyui scrollview
理解javascript的闭包,原型,和匿名函数(自己总结)一 .>关于闭包理解闭包 需要的知识1.变量的作用域例1:var n =99; //建立函数外的全局变量function readA(){ alert(n); //读取全局变量}readA(); //执行此函数例2:function readB(){ var c =..._iife 和 匿名函数
静态NAT、动态NAT实验拓扑:实验目的:熟悉网络地址转换协议掌握静态NAT 和动态NAT的配置分析静态NAT 和动态NAT的区别使用show命令来检查NAT的运行情况实验要求:按拓扑图来配置静态NAT 和动态NAT实验步骤:步骤1 按如上拓扑做好底层配置,并检验相邻设备之间的连通性步骤2在NAT 上配置一条到internet的缺省路由NAT(conf...
文章内容涉及IPV4,IPV6,ICMP等概念,无毒请放心食用
一、快捷键:1、 ctrl + a : 移动光标到行首【常用】2、 ctrl + e :移动光标到行尾【常用】3、 ctrl + d :删除光标之后的一个字符4、 ctrl + w : 删除行首到当前光标所在位置的所有字符【常用】5、 crtl + k : 删除当前光标到行尾的所有字符【常用】6、 alt + b : 打开快速启动栏7、 alt + 1/2/3… : 在多个不同的se...