plsql怎么设置定时任务带参数

avatar
作者
筋斗云
阅读量:0

要在PL/SQL中设置带参数的定时任务,可以使用DBMS_SCHEDULER包来实现。下面是一个简单的示例,演示如何设置一个带参数的定时任务:

DECLARE   l_job_name VARCHAR2(100) := 'MY_JOB';   l_job_action VARCHAR2(100) := 'BEGIN my_procedure(:param1, :param2); END;';   l_start_date TIMESTAMP := SYSTIMESTAMP;   l_interval INTERVAL DAY TO SECOND := INTERVAL '1' SECOND;   l_params DBMS_SCHEDULER.jobclass; BEGIN   DBMS_SCHEDULER.create_job(     job_name => l_job_name,     job_type => 'PLSQL_BLOCK',     job_action => l_job_action,     start_date => l_start_date,     repeat_interval => l_interval,     enabled => TRUE   );      l_params := DBMS_SCHEDULER.jobclass('param1', 'param2');   DBMS_SCHEDULER.set_job_arguments(job_name => l_job_name, argument_position => 1, argument_value => 'value1');   DBMS_SCHEDULER.set_job_arguments(job_name => l_job_name, argument_position => 2, argument_value => 'value2');      COMMIT; END; / 

在上面的示例中,我们首先定义了一个作业名称、作业动作、开始日期和重复间隔。然后使用DBMS_SCHEDULER.create_job()过程来创建一个PL/SQL类型的作业。接着使用DBMS_SCHEDULER.jobclass()来定义带有参数名和值的参数对象,并使用DBMS_SCHEDULER.set_job_arguments()来设置作业的参数值。

最后,我们提交了事务,从而使定时任务生效。您可以根据自己的需求修改参数和作业的属性。

    广告一刻

    为您即时展示最新活动产品广告消息,让您随时掌握产品活动新动态!