Oracle Job重建重走蹉跎之路(oracle job重建)


作为一名Oracle数据库管理员,我们经常需要维护数据库中的Job任务。Job任务可以帮助我们轻松地自动执行一些重复性的操作,例如备份、统计、清理日志等等。然而,在实际工作中,我们经常会遇到一些Job任务不执行或执行异常的情况。这时候,我们需要对这些Job任务进行重建,以达到让它们正常执行的目的。本文将从以下三个方面介绍如何重建Oracle Job任务,并结合代码进行讲解。

1.查看Job任务状态

我们需要查看当前Job任务的状态。可以使用以下SQL语句:

SELECT JOB_NAME, ENABLED, STATE FROM DBA_SCHEDULER_JOBS;

其中,JOB_NAME是任务的名称,ENABLED表示任务是否启用,STATE表示任务的状态。如果任务状态为BROKEN或FLED,则表示任务已经异常或者停止执行。我们需要对这些任务进行诊断,以确定原因。

2.重建Job任务

有两种方法可以重建Job任务:

方法一:先删除异常任务,再重新创建任务:

BEGIN

DBMS_SCHEDULER.DROP_JOB (job_name => ‘job_name’, force => TRUE);

END;

/

上述代码将删除名为‘job_name’的任务及其所有关联对象,包括程序、触发器等等。注意,使用force选项时会直接删除任务,如果任务尚未执行完成则会强制中断任务。

然后,我们需要重新创建任务。

BEGIN

DBMS_SCHEDULER.CREATE_JOB (

job_name =>’job_name’,

job_type =>’PLSQL_BLOCK’,

job_action =>’begin null;end;’,

start_date =>SYSTIMESTAMP,

repeat_interval =>’FREQ=DLY;INTERVAL=2′,

end_date =>NULL,

enabled =>TRUE,

comments =>’This is a test job’

);

END;

/

上述代码将创建一个名为‘job_name’的任务,执行一段空的PL/SQL块,调度方式为每隔两天执行一次。错误日志可以在表DBA_SCHEDULER_JOB_RUN_DETLS中查看。

方法二:修改异常任务,恢复任务执行:

BEGIN

DBMS_SCHEDULER.SET_ATTRIBUTE (

name => ‘job_name’,

attribute => ‘program_action’,

value => ‘begin null;end;’

);

END;

/

上述代码将修改名为‘job_name’的任务的程序执行语句为一段空的PL/SQL块。

3.优化Job任务

在进行Job任务维护的同时,我们可以考虑对Job任务做一些优化,以提高其执行效率。以下是一些优化建议:

①尽量减少任务的调度时间间隔,以减少数据操作的延迟。

②使用定制化的PL/SQL程序来执行任务,避免频繁地转换语言环境。

③使用合理的并发策略来调度任务,以避免资源的浪费。

总结

Job任务是Oracle数据库中非常重要的一部分,它可以为我们自动执行一些重复性的操作,提高工作效率。在任务出现异常或执行不正常的情况时,我们需要及时地进行维护和重建,以确保任务正常执行。同时,通过一些优化措施,可以进一步提高任务的执行效率,减少数据操作的延迟。