Oracle定时器---user_scheduler_jobs

user_scheduler_jobs 是 Oracle 数据库中的一个系统表,用于存储所有用户定义的调度器作业的信息。您可以使用该表来查询、创建、修改和删除调度器作业。以下是一些使用 user_scheduler_jobs 的示例:

  1. 查询所有调度器作业的信息:

SELECT * FROM user_scheduler_jobs;

     2.  创建一个新的调度器作业:

//给用户赋予 创建Job的权限
GRANT CREATE JOB TO User;

DECLARE
    sqlAction   VARCHAR2(1024);
BEGIN
    sqlAction := '
        DECLARE
            sqlCount	NUMBER;
            sqlStr      VARCHAR(64);
        BEGIN
            SELECT ... INTO sqlCount ...;
            
            UPDATE ... SET ...;
            INSERT INTO ...;
        END;
    ';
    
    DBMS_SCHEDULER.CREATE_JOB (
        job_name        => 'daily_job',
        job_type        => 'PLSQL_BLOCK',
        job_action      => sqlAction,
        start_date      => SYSTIMESTAMP,
        repeat_interval => 'FREQ=DAILY; BYHOUR=10', -- Every Monday at 8 o'clock
        enabled         => TRUE
    );

    COMMIT;
END;

代码将创建一个名为 daily_job的新调度器作业,该作业将在每天上午10点运行一次。

3.修改一个已存在的调度器作业:

BEGIN
  DBMS_SCHEDULER.SET_ATTRIBUTE (
    name             => 'daily_job',
    attribute        => 'repeat_interval',
    value            => 'FREQ=WEEKLY;BYDAY=TUE;BYHOUR=14;BYMINUTE=30;BYSECOND=0'
  );
END;

代码将修改名为 my_job 的调度器作业的重复间隔,将其更改为每周二下午2:30运行一次。

4.删除一个已存在的调度器作业:

BEGIN
  DBMS_SCHEDULER.DROP_JOB (
    job_name        => 'daily_job',      -- JOB的名称
    force           =>  FALSE            -- 是否强制删除JOB
  );
END;

  该代码将删除名为 daily_job 的调度器作业。

5.查看调度器工作历史:

select * from user_scheduler_job_log;
select * from user_scheduler_job_run_details;

相关操作

DBMS_JOB.RUN(40); -- 手工调用job id 为40的任务
dbms_job.remove(40); -- 删除job id  为40的任务
dbms_job.interval(job,interval); -- 修改间隔时间
dbms_job.next_date(job,next_date); -- 修改下次执行时间
dbms_job.what(jobno,'sp_fact_charge_code;');  --修改某个job名 

INTERVAL参数常用值示例

REPEAT_INTERVAL可选参数:
YEARLY(年), MONTHLY(月), WEEKLY(周), DAILY(日), HOURLY(时), MINUTELY(分), SECONDLY(秒)等单位。
INTERVAL 关键字用来指定间隔的频繁,可指定的值的范围从1-999。
BYHOUR 指定一天中的小时。可指定的值的范围从1-24。16,17,18就表示每天下午的4、5、6点。
BYDAY 关键字用来指定每周的哪天运行。
BYMONTHDAY 关键字用来指定每月中的哪一天。-1 表示每月最后一天。
BYMONTH 关键字用来指定每年的月份。
BYDATE 指定日期。0310就表示3月10日。

REPEAT_INTERVAL例子:
运行每星期五。(所有这三个例子是等价的。)
    FREQ=DAILY; BYDAY=FRI;
    FREQ=WEEKLY; BYDAY=FRI;
    FREQ=YEARLY; BYDAY=FRI;
设置任务隔一周运行一次,并且仅在周5运行:
    FREQ=WEEKLY; INTERVAL=2; BYDAY=FRI;
在每月的最后一天运行
    FREQ=MONTHLY; BYMONTHDAY=-1;
三月十日开。(两个例子是等价的)
    FREQ=YEARLY; BYMONTH=MAR; BYMONTHDAY=10;
    FREQ=YEARLY; BYDATE=0310;
设置任务每10隔天运行:
    REPEAT_INTERVAL => 'FREQ=DAILY; INTERVAL=10';
设置任务在每天的下午4、5、6点时运行:
    REPEAT_INTERVAL => 'FREQ=DAILY; BYHOUR=16,17,18';
设置任务在每月29日运行:
    REPEAT_INTERVAL => 'FREQ=MONTHLY; BYMONTHDAY=29';
设置任务在每年的最后一个周5运行:
    REPEAT_INTERVAL => 'FREQ=YEARLY; BYDAY=-1FRI';
设置任务每隔50个小时运行:
    REPEAT_INTERVAL => 'FREQ=HOURLY; INTERVAL=50';
每隔2小时运行一次job
    repeat_interval => 'FREQ=HOURLY; INTERVAL=2'
每天运行一次job
    repeat_interval => 'FREQ=DAILY'
每周的1,3,5运行job
    repeat_interval => 'FREQ=WEEKLY; BYDAY=MON,WED,FRI"
每年的3,6,9,12月的30号运行job
    repeat_interval => 'FREQ=YEARLY; BYMONTH=MAR,JUN,SEP,DEC; BYMONTHDAY=30'

以上是一些示例,您可以根据您的具体需求使用 user_scheduler_jobs 表和相关的调度器存储过程来管理您的调度器作业。

参考:https://blog.csdn.net/Nonoroya_Zoro/article/details/109115901?ops_request_misc=%257B%2522request%255Fid%2522%253A%2522172481301116800207065010%2522%252C%2522scm%2522%253A%252220140713.130102334.pc%255Fall.%2522%257D&request_id=172481301116800207065010&biz_id=0&utm_medium=distribute.pc_search_result.none-task-blog-2~all~first_rank_ecpm_v1~rank_v31_ecpm-23-109115901-null-null.142^v100^pc_search_result_base5&utm_term=user_scheduler_jobs&spm=1018.2226.3001.4187

`user_scheduler_jobs` 是 Oracle 数据库中的一个系统表,用于存储所有用户定义的调度器作业的信息。您可以使用该表来查询、创建、修改和删除调度器作业。以下是一些使用 `user_scheduler_jobs` 的示例: 1. 查询所有调度器作业的信息: ```sql SELECT * FROM user_scheduler_jobs; ``` 该查询将返回所有用户定义的调度器作业的详细信息,包括作业名称、作业类型、作业状态、开始时间、重复间隔等。 2. 创建一个新的调度器作业: ```sql BEGIN DBMS_SCHEDULER.CREATE_JOB ( job_name => 'my_job', job_type => 'PLSQL_BLOCK', job_action => 'BEGIN my_procedure; END;', start_date => SYSTIMESTAMP, repeat_interval => 'FREQ=DAILY;BYHOUR=10;BYMINUTE=0;BYSECOND=0' ); END; ``` 该代码将创建一个名为 `my_job` 的新调度器作业,该作业将在每天上午10点运行一次。 3. 修改一个已存在的调度器作业: ```sql BEGIN DBMS_SCHEDULER.SET_ATTRIBUTE ( name => 'my_job', attribute => 'repeat_interval', value => 'FREQ=WEEKLY;BYDAY=TUE;BYHOUR=14;BYMINUTE=30;BYSECOND=0' ); END; ``` 该代码将修改名为 `my_job` 的调度器作业的重复间隔,将其更改为每周二下午2:30运行一次。 4. 删除一个已存在的调度器作业: ```sql BEGIN DBMS_SCHEDULER.DROP_JOB ( job_name => 'my_job' ); END; ``` 该代码将删除名为 `my_job` 的调度器作业。 以上是一些示例,您可以根据您的具体需求使用 `user_scheduler_jobs` 表和相关的调度器存储过程来管理您的调度器作业。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值