谁帮忙写个计划任务
存储过程的名字为 Pro_test
要求是每月的后五天每天凌晨3点执行一次

解决方案 »

  1.   

    concat(to_char(last_day(date),'yyyy/mm/dd'),' 03:00:00')
    concat(to_char(last_day(date)-1,'yyyy/mm/dd'),' 03:00:00')
    concat(to_char(last_day(date)-2,'yyyy/mm/dd'),' 03:00:00')
    concat(to_char(last_day(date)-3,'yyyy/mm/dd'),' 03:00:00')
    concat(to_char(last_day(date)-4,'yyyy/mm/dd'),' 03:00:00')
    这样得出执行的时间点,然后当时间等于这几个时间点的时候执行存储过程,用Job应该可以吧,估计性能不好也比较笨,呵呵,听听楼下的高招
      

  2.   

    按你的要求只能折中一下:
    即:
    1.计划任务每天凌晨3点调存储过程Pro_test
    2.在存储过程Pro_test中加个判断:是否是每月的后五天--1.Job
    variable job number;
    begin
      sys.dbms_job.submit(job => :job,
                          what => Pro_test;',
                          next_date => trunc(sysdate),
                          interval => 'trunc(sysdate)+1+3/24');
      commit;
    end;
    /--2.Pro_test 中加判断
    if (last_day(sysdate)-sysdate)<=5 then
      --你原来存储过程的执行部分
      ;
    end if;
      

  3.   

    如果是linux或unix用crontab来完成吧,用一个sh脚本文件去调用(下面有详细).
    用oracle的job你参照一下这个:http://hanjs.itpub.net/post/28217/260148
    使用方式: 
      crontab [ -u user ] filecrontab [ -u user ] { -l | -r | -e } 
      说明: 
      crontab 是用来让使用者在固定时间或固定间隔执行程式之用,换句话说,也就是类似使用者的时程表。-u user 是指设定指定 user 的时程表,这个前提是你必须要有其权限(比如说是 root)才能够指定他人的时程表。如果不使用 -u user 的话,就是表示设定自己的时程表。 
      参数:   -e:执行文字编辑器来设定时程表,内定的文字编辑器是 VI,如果你想用别的文字编辑器,则请先设定 VISUAL 环境变数来指定使用那个文字编辑器(比如说 setenv VISUAL joe) 
      -r:删除目前的时程表 
      -l:列出目前的时程表   时程表的格式如下: 
      f1 f2 f3 f4 f5 program   其中 f1 是表示分钟,f2 表示小时,f3 表示一个月份中的第几日,f4 表示月份,f5 表示一个星期中的第几天。program 表示要执行的程式。 
      当 f1 为 * 时表示每分钟都要执行 program,f2 为 * 时表示每小时都要执行程式,其余类推 
      当 f1 为 a-b 时表示从第 a 分钟到第 b 分钟这段时间内要执行,f2 为 a-b 时表示从第 a 到第 b 小时都要执行,其余类推 
      当 f1 为 */n 时表示每 n 分钟个时间间隔执行一次,f2 为 */n 表示每 n 小时个时间间隔执行一次,其余类推 
      当 f1 为 a, b, c,... 时表示第 a, b, c,... 分钟要执行,f2 为 a, b, c,... 时表示第 a, b, c...个小时要执行,其余类推 
      使用者也可以将所有的设定先存放在档案 file 中,用 crontab file 的方式来设定时程表。 
      例子: 
      每月每天每小时的第 0 分钟执行一次 /bin/ls: 
      0 7 * * * /bin/ls   在 12 月内, 每天的早上 6 点到 12 点中,每隔 20 分钟执行一次 /usr/bin/backup: 
      0 6-12/3 * 12 * /usr/bin/backup   周一到周五每天下午 5:00 寄一封信给 [email protected]
      0 17 * * 1-5 mail -s \"hi\" [email protected] < /tmp/maildata   每月每天的午夜 0 点 20 分, 2 点 20 分, 4 点 20 分....执行 echo \"haha\" 
      20 0-23/2 * * * echo \"haha\"   注意: 
      当程式在你所指定的时间执行后,系统会寄一封信给你,显示该程式执行的内容,若是你不希望收到这样的信,请在每一行空一格之后加上 > /dev/null 2>&1 即可。 
      

  4.   

    2楼的不错啊,定时任务oracle就是 job实现啊!
      

  5.   

    如果是linux或unix用crontab来完成,如果是WINDOWS直接用计划任务,这种方法相对比较简单。
      

  6.   

    如果是Oracle10g,可以用强大的dbms_scheduler代替dbms_job,而且很容易就能实现楼主所需要的功能
    BEGIN
      DBMS_SCHEDULER.CREATE_JOB(
    job_name=>'auto_exec_pro_test',
    job_type=>'STORED_PROCEDURE',
    job_action=>'pro_test',
    start_date=>SYSDATE,
    repeat_interval=>'FREQ=MONTHLY; BYMONTHDAY=-1,-2,-3,-4,-5; BYHOUR=3',
    enabled=>TRUE);
    END;
    /