oracle 添加一个计划任务 每天凌晨两点 定时执行一个存储过程 求详细步骤!!急!!
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了oracle 添加一个计划任务 每天凌晨两点 定时执行一个存储过程 求详细步骤!!急!!相关的知识,希望对你有一定的参考价值。
下面是我写的JOB
begin
sys.dbms_job.submit(job => :2,
what => 'p_dlbi;',
next_date => to_date('08-01-2013 01:00:00', 'dd-mm-yyyy hh24:mi:ss'),
interval => 'trunc(SYSDATE + 1,''mi'')');
commit;
end;
运行之后报ORA-01008错误
v_HH24 CHAR(2) := '00';
begin后面给变量赋值:
v_HH24 := to_char(sysdate, 'HH24');
然后在你执行的代码外面加上:
IF v_HH24 = '02' THEN
你的代码;
end if;
然后使用下面的脚本创建job:
begin
sys.dbms_job.submit(job => :job,
what => '你的存储过程名字;',
next_date => to_date('01-06-2013 00:00:00', 'dd-mm-yyyy hh24:mi:ss'),
interval => 'SYSDATE+60/1440');
commit;
end;
/ 参考技术A 你去看看oracle中的触发器Trigger使用方法吧,我也不是太会用,多看点就会了的 参考技术B 试试这个,TOAD上是OK的
variable job_feeid_create NUMBER;
begin
sys.dbms_job.submit(:job_feeid_create,'p_dlbi',sysdate,'TRUNC(SYSDATE + 1) + 120/1440' );
commit;
end; 参考技术C DECLARE
X NUMBER;
BEGIN
SYS.DBMS_JOB.SUBMIT
(
job => X
,what => 'p_dlbi;'
,next_date =>TRUNC(SYSDATE+1)+2/24
,interval => 'TRUNC(SYSDATE+1)+2/24'
,no_parse => FALSE
);
:JobNumber := to_char(X);
END;
java Timer 定时每天凌晨0点执行任务
import java.util.TimerTask; /** * 执行内容 * @author admin_Hzw * */ public class Task extends TimerTask { public void run() { System.out.println("我有一头小毛驴!"); }
import java.util.Calendar; import java.util.Date; import java.util.Timer; /** * 任务管理 * @author admin_Hzw * */ public class TimerManager { /** * @param args */ public static void main(String[] args) { new TimerManager(); } //时间间隔(一天) private static final long PERIOD_DAY = 24 * 60 * 60 * 1000; public TimerManager() { Calendar calendar = Calendar.getInstance(); calendar.set(Calendar.HOUR_OF_DAY, 1); //凌晨1点 calendar.set(Calendar.MINUTE, 0); calendar.set(Calendar.SECOND, 0); Date date=calendar.getTime(); //第一次执行定时任务的时间 //如果第一次执行定时任务的时间 小于当前的时间 //此时要在 第一次执行定时任务的时间加一天,以便此任务在下个时间点执行。如果不加一天,任务会立即执行。 if (date.before(new Date())) { date = this.addDay(date, 1); } Timer timer = new Timer(); Task task = new Task(); //安排指定的任务在指定的时间开始进行重复的固定延迟执行。 timer.schedule(task,date,PERIOD_DAY); } // 增加或减少天数 public Date addDay(Date date, int num) { Calendar startDT = Calendar.getInstance(); startDT.setTime(date); startDT.add(Calendar.DAY_OF_MONTH, num); return startDT.getTime(); } }
以上是关于oracle 添加一个计划任务 每天凌晨两点 定时执行一个存储过程 求详细步骤!!急!!的主要内容,如果未能解决你的问题,请参考以下文章