当前位置: 首页 > news >正文

oracle定时任务的使用

常见错误:

PLS-00225: subprogram or cursor 'xxx' reference is out of scope
# job名字太长
PLS-00201: identifier 'COUNT_JOB.SUBMIT' must be declared
# DBMS_JOB.SUBMIT是固定写法

创建存储过程

-- 建表
CREATE TABLE TEST_A(TEST_ADD_DATA DATE);
-- 存储过程
CREATE OR REPLACE PROCEDURE TEST_PRO AS
BEGININSERT INTO TEST_A VALUES (SYSDATE);
END;

创建定时任务JOB

DECLARE jobno number;    -- UPDATE_COUNT_TIME:给函数定义的工作空间
BEGINSYS.DBMS_JOB.SUBMIT(job => jobno,    -- 调用工作空间what => 'TEST_PRO;',    -- 工作空间中执行的函数next_date => SYSDATE,    -- 下一次执行的时间,不要改,貌似是这样子,不太确定interval => 'TRUNC(LAST_DAY(SYSDATE))+1+1/24');    -- 每月1日凌晨1点执行
commit;
End;或者DECLAREjobno NUMBER;
BEGINdbms_job.submit(jobno, --定时器ID,系统自动获得'TEST_PRO;', --what执行的过程名SYSDATE, --next_date,定时器开始执行的时间,这样写表示立即执行'TRUNC(sysdate,''mi'') + 1/ (24*60)' --interval,设置定时器执行的频率,这样写每隔1分钟执行一次);COMMIT;
END;

说明:

1、declare后面的 jobno 是一个数字类型,主要的用途是给定时器保存id,下面的job 引用此 jobno 。

2、job:输出变量,是此任务在任务队列中的编号;

3、what:执行的任务的名称及其输入参数;

4、next_date:任务执行的时间;

5、interval:任务执行的时间间隔。

手动执行定时任务

下面的参数需要根据本地查询的参数来确定

BEGINDBMS_JOB.RUN(26);COMMIT;
END;

停止定时任务

BEGINDBMS_JOB.BROKEN(26,  TRUE,  SYSDATE);COMMIT;
END;

删除定时任务

BEGINDBMS_JOB.REMOVE(26);commit;
END;

注意:26为job的编号,可通过如下语句查询

-- 查看调度任务
select * from user_jobs;-- 查看正在执行的调度任务
select * from dba_jobs_running;-- 查看执行完的调度任务
select * from dba_jobs;SELECT job,what,log_user,priv_user,broken from dba_jobs 

常见的Interval 设置

描述                        INTERVAL参数值 
每天午夜12点                 TRUNC(SYSDATE + 1) 
每天早上8点30分              TRUNC(SYSDATE + 1) + (8*60+30)/(24*60) 
每星期二中午12点              NEXT_DAY(TRUNC(SYSDATE ), ''TUESDAY'' ) + 12/24 
每个月第一天的午夜12点         TRUNC(LAST_DAY(SYSDATE ) + 1) 
每个季度最后一天的晚上11点      TRUNC(ADD_MONTHS(SYSDATE + 2/24, 3 ), 'Q' ) -1/24 
每星期六和日早上6点10分        TRUNC(LEAST(NEXT_DAY(SYSDATE, ''SATURDAY"), NEXT_DAY(SYSDATE, "SUNDAY"))) + (6×60+10)/(24×60)
每秒钟执行次Interval => sysdate + 1/(24 * 60 * 60)如果改成sysdate + 10/(24 * 60 * 60)就是10秒钟执行次每分钟执行 
Interval => TRUNC(sysdate,'mi') + 1/ (24*60)如果改成TRUNC(sysdate,'mi') + 10/ (24*60) 就是每10分钟执行次每天定时执行 
例如:每天的凌晨1点执行 
Interval => TRUNC(sysdate) + 1 +1/ (24)每周定时执行 
例如:每周一凌晨1点执行 
Interval => TRUNC(next_day(sysdate,'星期一'))+1/24每月定时执行 
例如:每月1日凌晨1点执行 
Interval =>TRUNC(LAST_DAY(SYSDATE))+1+1/24每季度定时执行 
例如每季度的第一天凌晨1点执行 
Interval => TRUNC(ADD_MONTHS(SYSDATE,3),'Q') + 1/24每半年定时执行 
例如:每年7月1日和1月1日凌晨1点 
Interval => ADD_MONTHS(trunc(sysdate,'yyyy'),6)+1/24每年定时执行 
例如:每年1月1日凌晨1点执行 
Interval =>ADD_MONTHS(trunc(sysdate,'yyyy'),12)+1/24

创建定时器

  1. 创建存储过程或函数,例如:

    CREATE OR REPLACE FUNCTION my_func(
    p_param1 IN VARCHAR2,
    p_param2 IN NUMBER)RETURN NUMBER
    IS  result NUMBER;
    BEGIN  -- do something with parameters 
    result := 1; -- example 
    return value 
    RETURN result;END;
    
  2. 创建一个作业,指定要调用的函数和参数,例如

    BEGIN 
    DBMS_SCHEDULER.CREATE_JOB (    
    job_name => 'my_job',    
    job_type => 'STORED_PROCEDURE',   
    job_action => 'my_func',   
    number_of_arguments => 2,   
    start_date => SYSTIMESTAMP,   
    repeat_interval => 'FREQ=DAILY;BYHOUR=8;BYMINUTE=30',    
    auto_drop => FALSE,   
    enabled => TRUE); DBMS_SCHEDULER.SET_JOB_ARGUMENT_VALUE (   
    job_name => 'my_job',   
    argument_position => 1,   
    argument_value => 'param1_value'); DBMS_SCHEDULER.SET_JOB_ARGUMENT_VALUE (   
    job_name => 'my_job', 
    argument_position => 2,    
    argument_value => 123);
    END;
    

3、repeat_interval

-- repeat_interval 支持两种格式
1. 常规日期格式   (1) 每天:sysdate + 1   2. 日历表达式('FREQ': 频率,'INTERVAL':范围 1-999,可选:BY...)FREQ=DAILY; INTERVAL=1 										 每天执行一次 FREQ=WEEKLY; INTERVAL=1; BYDAY=MON							 每周一执行一次FREQ=WEEKLY; INTERVAL=1; BYDAY=MON,FRI						 每周一,周五执行一次FREQ=WEEKLY; INTERVAL=1; BYDAY=MON; BYHOUR=8					 每周一早上8点执行一次FREQ=MONTHLY; INTERVAL=1; BYMONTHDAY=1; BYHOUR=8; BYMINUTE=30 每月第一天早上8点30分执行一次(1) FREQYEARLY   年  MONTHLY  月 WEEKLY   周 DAILY    天		  HOURLY   时  MINUTELY 分  SECONDLY 秒(2) INTERVAL1 ~ 999(3) BYMONTHJAN 一月    -- JanuaryFEB 二月    -- FebruaryMAR 三月    -- MarchAPR 四月    -- AprilMAY 五月    -- MayJUN 六月    -- JuneJUL 七月    -- JulyAUG 八月    -- AugustSEP 九月    -- SeptemberOCT 十月    -- OctoberNOV 十一月  -- FebruaryDEC 十二月  -- December(4) BYDAYMON  周一  -- MondayTUE  周二  -- TuesdayWED  周三  -- WednesdayTHU  周四  -- ThursdayFRI  周五  -- FridaySAT  周六  -- SaturdaySUN  周天  -- Sunday  (5) BYHOUR(6) BYMINUTE(7) BYSECOND

定时器手动执行

手动执行定时器— job_name 是要运行的作业名称。

使用以下命令将作业设置为可运行状态:

EXECUTE DBMS_SCHEDULER.ENABLE('job_name');

使用以下命令运行作业:

 EXECUTE DBMS_SCHEDULER.RUN_JOB('job_name');

使用以下命令检查作业的状态:

 SELECT job_name, state FROM dba_scheduler_jobs WHERE job_name = 'job_name';
# 可能的状态包括:SCHEDULED、RUNNING、COMPLETED 和 FAILED

修改删除

BEGIN  -- 修改作业  DBMS_SCHEDULER.SET_ATTRIBUTE(    name => 'my_job',   attribute => 'repeat_interval',    value => 'FREQ=DAILY;BYHOUR=9;BYMINUTE=0'); -- 删除作业  DBMS_SCHEDULER.DROP_JOB('my_job');
END;

手动调用函数、存储过程

当函数中有dml语句的时候,函数调用不能在select和if里面使用,此时需要手动调用函数

 select suc_function(sysdate,'all') from dual;
-- 执行函数
DECLARE
variable_name varchar2(100);
BEGIN
variable_name := suc_function(sysdate,'all');
END;-- 执行存储过程
call  suc_procedure_data( trunc(sysdate-6),'CPJ')

https://blog.csdn.net/qq_34745941/article/details/111660478

https://blog.csdn.net/KevinChen2019/article/details/128256517

http://www.lryc.cn/news/177536.html

相关文章:

  • VSCode 配置 Lua 开发环境(清晰明了)
  • JS合并2个远程pdf
  • TikTok的伦理挑战:虚拟世界与现实世界的交汇
  • C# 获取磁盘空间大小的方法
  • JVM机制理解与调优方案
  • Django的设计模式及模板层
  • 写代码生成流程图
  • python reportlab生成pdf
  • 第一次作业题解
  • 美篇作文网教学资源源码-自带作文数据
  • 电脑软件:Duplicate Cleaner Pro 5.16 重复文件清理软件(附下载)
  • 支持笔记本电脑直插直充,TOWE 65W智能快充PDU超级插座
  • 部署Kafka
  • Open3D 进阶(11)使用GMM-Tree算法对点云配准
  • 算法刷题注意事项
  • 搭建自己的pypi服务器
  • ndoe.js、npm相关笔记
  • 如何使用ArcGIS Pro制作标准地图样式国界
  • 基于数学模型水动力模拟、水质建模、复杂河网构建技术在环境影响评价、入河排污口论证及防洪评价中的应用
  • 每天学习3个小时能不能考上浙大MBA项目?
  • NVM的下载安装和使用
  • iOS 视频压缩 mov转mp4 码率
  • 基于Esp32-cam在无外部 PIR 传感器情况下实现运动检测(一)
  • 安卓recovery流程分析(编译、界面、图片)
  • 唤醒手腕 2023年 B 站课程 Golang 语言详细教程笔记(更新中)
  • Qt获取屏幕(桌面)的大小或分辨率
  • 第4讲:vue内置命令(文本插值,属性绑定,v-text,v-html)
  • vue实现自动生成路由,非手动创建,含避坑点
  • 数据挖掘note(赵老师语录)
  • 秋招在线人才测评考什么内容?