每月的后五天每天凌晨3点执行一次的计划任务 谁帮忙写个计划任务存储过程的名字为 Pro_test要求是每月的后五天每天凌晨3点执行一次 解决方案 » 免费领取超大流量手机卡,每月29元包185G流量+100分钟通话, 中国电信官方发货 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应该可以吧,估计性能不好也比较笨,呵呵,听听楼下的高招 按你的要求只能折中一下:即:1.计划任务每天凌晨3点调存储过程Pro_test2.在存储过程Pro_test中加个判断:是否是每月的后五天--1.Jobvariable 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; 如果是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 即可。 2楼的不错啊,定时任务oracle就是 job实现啊! 如果是linux或unix用crontab来完成,如果是WINDOWS直接用计划任务,这种方法相对比较简单。 如果是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;/ sqlldr 急求报表打印REP-501问题解决方法 SQL查询语句 在查询表时,我想把表名最后一位是数字的表查询出来 oracle management server中没有数据库 各位大虾,Oracle怎么连SQL Server 2000?谢谢!!! 在sql里将两个select进行合并和进行交集应该怎么做? 如何登录 ◆◆请教高手?关于在不同系统下的导出及导入◆◆ 更改数据库后的问题 oracle查不在表里的记录 Insert 性能问题
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应该可以吧,估计性能不好也比较笨,呵呵,听听楼下的高招
即:
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;
用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 即可。
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;
/