0

我正在尝试在 oracle 10g 数据库中创建一个简单的预定事件。我一直在尝试使用 dbms_scheduler.create_job。这是我写的脚本:

开始 dbms_scheduler.create_job (

job_name => 'disengagementChecker',

job_type => 'PLSQL_BLOCK',

job_action => 'INSERT INTO PatientClassRelObs(patientClassID,observationTypeID) VALUES (1, 11)',

开始日期 => SYSDATE,

repeat_interval => 'FREQ=MINUTELY;INTERVAL=1',

评论 => '我正在测试调度程序'); 结尾;

当我运行它时,oracle 会抛出这些错误

ORA-06550:第 15 行,第 3 列:

PLS-00103:在预期以下情况之一时遇到符号“文件结尾”:

; 符号“;” 被替换为“文件结尾”以继续。

我不明白是什么导致了这个错误。你知道是什么导致了这个错误吗?或者为什么会这样?

先感谢您!

-大卫

4

1 回答 1

0

JOB_ACTION必须是有效的 PL/SQL 块,而不仅仅是有效的 SQL 语句。用这个:

job_action => '
  BEGIN
    INSERT INTO PatientClassRelObs(patientClassID,observationTypeID)
    VALUES (1, 11);
  END;',

更新

也许这是特定环境的问题或未发布的某些代码。要进行故障排除,请从已知可行的方法开始,然后一次添加一个小的更改,直到出现问题。

从这段代码开始,使用 SQL*Plus。

SQL> begin
  2     dbms_scheduler.create_job(
  3             job_name   => 'TEST_JOB',
  4             job_type   => 'PLSQL_BLOCK',
  5             job_action => 'BEGIN NULL; END;',
  6             start_date => systimestamp,
  7             enabled    => true);
  8  end;
  9  /

PL/SQL procedure successfully completed.

SQL> select status, log_date from dba_scheduler_job_run_details where job_name = 'TEST_JOB';

STATUS                         LOG_DATE
------------------------------ ---------------------------------------------------------------------------
SUCCEEDED                      26-MAR-14 11.37.59.533000 PM -05:00
于 2014-03-27T03:59:16.637 回答