当前位置: 首页 > 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

相关文章:

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); -- 存储过程 C…...

VSCode 配置 Lua 开发环境(清晰明了)

概述 由于 AutoJS 学得已经差不多了,基本都会了,现在开始向其他游戏脚本框架进发, Lua 语言很强大,就不多说, 按键精灵、触动精灵等等都是用该语言编程脚本的,由于按键精灵、触动精灵 和 AutoJS 类似,不是…...

JS合并2个远程pdf

要在HTML和JavaScript中读取远程PDF文件的矢量数据并合并两个PDF文件,您可以使用pdf-lib和Axios库。以下是使用pdf-lib和Axios在HTML和JavaScript中读取和合并远程PDF文件的步骤: 1. 引入 首先,确保您在HTML文件中引入了pdf-lib和Axios库。…...

TikTok的伦理挑战:虚拟世界与现实世界的交汇

在数字时代,社交媒体平台已经不再只是一个信息传播的工具,它已经深刻地改变了我们的社交行为、价值观和伦理观。 而在这一领域的佼佼者之一,TikTok,正面临着伦理挑战,这是虚拟世界与现实世界交汇的产物。 本文将深入…...

C# 获取磁盘空间大小的方法

方法一:利用System.IO.DriveInfo.GetDrives方法来获取 /// 获取指定驱动器的空间总大小(单位为B)////// 只需输入代表驱动器的字母即可 (大写)///public static long GetHardDiskSpace(string str_HardDiskName){long totalSize new long();…...

JVM机制理解与调优方案

作者:逍遥Sean 简介:一个主修Java的Web网站\游戏服务器后端开发者 主页:https://blog.csdn.net/Ureliable 觉得博主文章不错的话,可以三连支持一下~ 如有需要我的支持,请私信或评论留言! 前言 很多Java开发…...

Django的设计模式及模板层

Django的设计模式及模板层 设计模式MVC和MVT MVC 代表 Model-View-Controller(模型-视图-控制器)模式。 M 模型层(Model),主要用于对数据库层的封装 V 视图层(View),用于向用户展示结果 (WHAT HOW) C 控制(Controller,用于处理请求、获取数据、返回结果(重要) 作…...

写代码生成流程图

我们在写文档,博客的时候,一般都会使用markdown语法,最常见的就是一些github开源项目的README。有时候会去画一些流程图,例如使用process.on或者xmind等第三方网站,然后截图插入到文档中。 今天我们介绍一种使用代码直…...

python reportlab生成pdf

这里自定义了pagetemplate,使用BaseDocTemplate,但我感觉一般使用SimpleDocTemplate就可以。 from reportlab.platypus import Frame from reportlab.lib.pagesizes import A4, landscapepadding dict(leftPadding72,rightPadding72,topPadding72,bott…...

第一次作业题解

第一次作业题解 P5717 【深基3.习8】三角形分类 思路 考的是if()的使用,还要给三条边判断大小 判断优先级&#xff1a; 三角形&#xff1f;直角、钝角、锐角等腰等边 判断按题给顺序来 代码 #include <stdio.h> int main() {int a 0, b 0, c 0, x 0, y 0, z 0…...

美篇作文网教学资源源码-自带作文数据

非常漂亮的UI设计和页面排版&#xff01; 自适应手机pc端 页面内容均支持自定义 可以用来做网站矩阵&#xff0c;或者增强你其他网站板块&#xff0c;或者单独运营都可以。 可以通过广告方式变现&#xff0c;或者引流等等 友好的seo&#xff0c;更容易被浏览器收录 关注青狐…...

电脑软件:Duplicate Cleaner Pro 5.16 重复文件清理软件(附下载)

大家平时在使用电脑的时候&#xff0c;会经常从网上下载文件或者从其他电脑拷贝文件到自己的电脑上。久而久之就会在电脑中存放很多相同的文件&#xff0c;并且会越积越多&#xff0c;不仅占用很多磁盘空间&#xff0c;在文件管理上也非常混乱不方便。如何解决呢&#xff1f; …...

支持笔记本电脑直插直充,TOWE 65W智能快充PDU超级插座

电源插排在我们的生活中是必不可少的电器配件。今天&#xff0c;我们日常生活中所使用的电子设备越来越多&#xff0c;无论是手机、平板、笔记本电脑还是各种家用电器&#xff0c;都需要电源来驱动。虽然相对于其他电器来说&#xff0c;插排结构比较简单&#xff0c;但现代家庭…...

部署Kafka

kafka&#xff1a;kafka_2.13-3.5.1 NOTE: Your local environment must have Java 8 installed. Apache Kafka can be started using ZooKeeper or KRaft. To get started with either configuration follow one the sections below but not both. 1 Windows单机 1.1 Kafka w…...

Open3D 进阶(11)使用GMM-Tree算法对点云配准

GMM-Tree算法 一、算法原理1、主要函数2、参考文献二、代码实现三、结果展示1、点云初始位置2、配准后的位置四、测试数据本文由CSDN点云侠原创,原文链接。如果你不是在点云侠的博客中看到该文章,那么此处便是不要脸的爬虫。 一、算法原理 1、...

算法刷题注意事项

目录 1、使用nextInt后再使用nextLine的注意事项2、判断x是否是素数3、注意字符串和数字的排序4、Arrays.asList不可修改元素 1、使用nextInt后再使用nextLine的注意事项 使用nextInt再使用nextLine会有问题&#xff0c;输入的回车会被nextLine给接受&#xff0c;可以将nextLi…...

搭建自己的pypi服务器

要搭建自己的 PyPI 服务器&#xff0c;您可以使用 warehouse 项目&#xff0c;它是 PyPI 的开源实现。下面是一些基本步骤&#xff1a; 准备环境&#xff1a; 安装 Python安装 PostgreSQL 数据库 克隆 warehouse 项目&#xff1a; git clone https://github.com/pypa/wareh…...

ndoe.js、npm相关笔记

1、npm 全局安装 npm config get prefix 获取 npm 全局安装路径如果全局插件不能正常使用&#xff0c;看环境变量是否已经配置。没有配置则把全局安装路径配置到环境变量的path中...

如何使用ArcGIS Pro制作标准地图样式国界

相信大家都浏览过标准地图服务提供的标准地图&#xff0c;不知道你有没有想过尝试制作里面的国界&#xff0c;这里为大家介绍一下制作方法&#xff0c;希望能对你有所帮助。 制作已定国界 在地图数据内&#xff0c;国界分为已定国界、未定国界和海岸线&#xff0c;我们先对已定…...

基于数学模型水动力模拟、水质建模、复杂河网构建技术在环境影响评价、入河排污口论证及防洪评价中的应用

目录 专题一 一维水动力模型在河流水动力模拟中的应用 专题二 一维复杂河网模型构建及建筑物设置 专题三 一维水质模型在入河排污口和环境影响评价中的应用 专题四 平面二维水动力模型的构建和验证 专题五 平面二维水动力模型在防洪影响评价中的应用 专题六 平面二维水动…...

汽车软件平台演进:从AUTOSAR到Hypervisor,如何重塑开发与商业模式

1. 汽车软件平台现状&#xff1a;从“硬骨头”到“乐高积木”的演进干了十几年汽车电子&#xff0c;我亲眼看着车里的代码从几万行膨胀到上亿行。十年前&#xff0c;我们还在为某个ECU&#xff08;电子控制单元&#xff09;里塞进一个简单的网络协议栈而通宵调试&#xff1b;现…...

当AI开始写代码,测试工程师的挑战才刚刚开始

最近&#xff0c;我让五款主流的AI编程工具完成了同一个开发需求&#xff0c;结果让我这个做了八年测试的老兵深受震撼。不是为了比较谁写的代码更“优雅”&#xff0c;而是从测试的角度&#xff0c;我看到了未来五年软件质量保障工作的全新图景。 我们测试从业者正站在一个十…...

维他动力获5亿Pre-A轮启动人形研发;优必选与日立达成合作人形机器人赋能制造; 前小米高管创业工业通用具身大脑小雨智造获B+轮融资

1. 维他动力获5亿Pre-A轮启动人形研发牛喀网获悉&#xff0c;Vbot维他动力正式完成近5亿元Pre-A轮融资&#xff0c;创下当前消费级具身智能领域的最大单笔融资纪录&#xff0c;本轮由东方嘉富、华泰紫金、复星锐正联合领投&#xff0c;上汽旗下尚颀资本等机构参投。技术层面&am…...

不删除属性的情况下简化对象属性的方法探讨

是否还有其他方法可以简化从对象中删除特定属性的操作。舍友提出了一个对象属性简化的问题&#xff0c;询问在不删除属性的情况下&#xff0c;如何简化从对象中删除特定属性的操作。02解决方案最初&#xff0c;我曾考虑过不直接删除属性&#xff0c;而是仅保留业务所需的那些。…...

AI智能体编排平台OpenClaw-Core:构建标准化、可复用的AI工作流

1. 项目概述&#xff1a;从“单打独斗”到“交响乐团”的AI协作革命 如果你和我一样&#xff0c;在过去几年里深度使用过各种大语言模型&#xff0c;那你一定经历过这种“甜蜜的烦恼”&#xff1a;ChatGPT在创意写作上天马行空&#xff0c;但在代码生成上偶尔会“一本正经地胡说…...

Nitric常见问题解答:开发者最关心的25个问题汇总

Nitric常见问题解答&#xff1a;开发者最关心的25个问题汇总 【免费下载链接】nitric Nitric is a multi-language framework for cloud applications with infrastructure from code. 项目地址: https://gitcode.com/gh_mirrors/ni/nitric Nitric是一个多语言框架&…...

用C8051F单片机自带的12位ADC,实现16位精度的温度测量(附完整代码)

基于C8051F单片机12位ADC实现16位温度测量的工程实践 在嵌入式系统开发中&#xff0c;高精度温度测量往往需要昂贵的16位ADC芯片&#xff0c;但通过合理的算法设计&#xff0c;我们可以利用C8051F系列单片机内置的12位ADC实现等效16位的测量精度。本文将深入探讨过采样技术的实…...

期刊论文发表难破局:虎贲等考 AI 以真文献 + 强实证,大幅提升录用率

在职称评审、毕业要求、科研考核的多重压力下&#xff0c;期刊论文早已成为硬指标。可现实是&#xff1a;投稿容易录用难&#xff0c;初审因选题、文献、实证、格式任意一点不合格就被拒稿&#xff0c;返修反复消耗数月。通用 AI 只能堆砌文字、编造来源&#xff0c;普通工具仅…...

告别网盘限速困扰:网盘直链下载助手全面解析与应用指南

告别网盘限速困扰&#xff1a;网盘直链下载助手全面解析与应用指南 【免费下载链接】baiduyun 油猴脚本 - 一个免费开源的网盘下载助手 项目地址: https://gitcode.com/gh_mirrors/ba/baiduyun 还在为网盘下载速度缓慢而烦恼吗&#xff1f;网盘直链下载助手作为一款免费…...

202X年CSDN年度技术趋势大预测

好的&#xff0c;以下是一篇关于CSDN年度技术趋势预测的技术文章大纲&#xff1a;202X年CSDN年度技术趋势预测&#xff1a;引领未来的技术变革一、引言技术发展的加速与变革年度技术趋势对行业的影响本文预测的依据与方法论二、人工智能与生成式AI的深化应用大模型技术的演进方…...