在命令窗口中执行。
variable后面的变量名要和 后面 job=> :job(这个一样),要不然会报“并非所有变量都已绑定”错误。执行成功后,job号会由oracle自动生成。
一般在用job调用存储过程中,会在存储过程中加oracle异常处理,否则job出错后无法查错。
1.创建job(注意其中next_date要写好!需要什么时间,就写什么时间)
variable job1 number; begin sys.dbms_job.submit(job => :job1, what => 'p_main3_main1;', next_date => to_date('01-02-2012 11:47:25', 'dd-mm-yyyy hh24:mi:ss'), interval => 'SYSDATE+4/86400/5'); commit; end; /
2.oracle异常处理(在存储过程中)
2.1先创建错误日志表
create table t_sys_errors( e_user varchar2(100), e_date date, error_code number, error_message varchar2(255)) ;
2.2存储过程中将异常记录到日志表中
declare error_code number; -->定义变量, error_message varchar2(255); --> 11g 是 512, 10g 是 255 begin ... exception when others then rollback; error_code := sqlcode; -->将错误号,放到 变量里面 error_message := sqlerrm -->将错误信息,放到 变量里面 insert into errors(e_user,e_date,error_code,error_message) values (user,sysdate,error_code,error_message); -->将错误号,和信息放到 日志表里面 end;