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 添加一个计划任务 每天凌晨两点 定时执行一个存储过程 求详细步骤!!急!!的主要内容,如果未能解决你的问题,请参考以下文章

我要在oracle 10g创建一个job,每天凌晨9点执行一个过程,过程名假定为 pro_1001 谢谢指点

linux定时任务

设置定时任务为每天凌晨2点执行和每小时执行一次

oracle 定时任务

php实现每天凌晨1点处理订单的问题

java Timer 定时每天凌晨0点执行任务