当前位置:网站首页>oracle 存储过程与job任务设置
oracle 存储过程与job任务设置
2022-07-02 04:32:00 【號先生】
oracle 存储过程,删除语法
查询语法字段解析:
字段(列) 类型 描述
JOB NUMBER 任务的唯一标示号
LOG_USER VARCHAR2(30) 提交任务的用户
PRIV_USER VARCHAR2(30) 赋予任务权限的用户
SCHEMA_USER VARCHAR2(30) 对任务作语法分析的用户模式
LAST_DATE DATE 最后一次成功运行任务的时间
LAST_SEC VARCHAR2(8) 如HH24:MM:SS格式的last_date日期的小时,分钟和秒
THIS_DATE DATE 正在运行任务的开始时间,如果没有运行任务则为null
THIS_SEC VARCHAR2(8) 如HH24:MM:SS格式的this_date日期的小时,分钟和秒
NEXT_DATE DATE 下一次定时运行任务的时间
NEXT_SEC VARCHAR2(8) 如HH24:MM:SS格式的next_date日期的小时,分钟和秒
TOTAL_TIME NUMBER 该任务运行所需要的总时间,单位为秒
BROKEN VARCHAR2(1) 标志参数,Y标示任务中断,以后不会运行
INTERVAL VARCHAR2(200) 用于计算下一运行时间的表达式
FAILURES NUMBER 任务运行连续没有成功的次数
WHAT VARCHAR2(2000) 执行任务的PL/SQL块
CURRENT_SESSION_LABELRAW MLSLABEL 该任务的信任Oracle会话符
CLEARANCE_HI RAW MLSLABEL 该任务可信任的Oracle最大间隙
CLEARANCE_LO RAW MLSLABEL 该任务可信任的Oracle最小间隙
NLS_ENV VARCHAR2(2000) 任务运行的NLS会话设置
MISC_ENV RAW(32) 任务运行的其他一些会话参数
查询任务:
select * from dba_jobs;
select * from all_jobs;
select * fromuser_jobs;
正在运行job
select * from dba_jobs_running;
创建存储过程:
CREATE OR REPLACE procedure DELETE_MSG_POTENTIAL_VICTIM is
begin
begin
delete from MSG_POTENTIAL_VICTIM where TO_CHAR (CREATETIME,'YYYY-MM-DD') = TO_CHAR(SYSDATE -1,'YYYY-MM-DD');
commit;
end;
end;
oracle存储过程,删除分区数据
CREATE OR REPLACE PROCEDURE add_part_moth IS
v_1 VARCHAR2(500);
v_4 VARCHAR2(1000);
v_5 VARCHAR2(1000);
BEGIN
v_1 := 'p_' || to_char(add_months(SYSDATE,1),'YYYYMM');
v_2 := to_number(to_char(TRUNC(add_months(SYSDATE,2), 'MM'),'YYYYMMDD'));
v_4 := 'alter table MOBILE_CALLEDZONE_MONTH add partition ' || v_1 || ' values less than (TO_DATE(' || '''' || v_2 || ' 00:00:00' || '''' || ',' || '''' || 'YYYYMMDD HH24:MI:SS' || '''' || ')) tablespace plsspace_stat';
v_5 := 'alter table NUMBERS_MONTH add partition ' || v_1 || ' values less than (TO_DATE(' || '''' || v_2 || ' 00:00:00' || '''' || ',' || '''' || 'YYYYMMDD HH24:MI:SS' || '''' || ')) tablespace plsspace_stat';
BEGIN
EXECUTE IMMEDIATE v_4;
END;
BEGIN
EXECUTE IMMEDIATE v_5;
END;
END;
Oracle的 配置job任务
-- 创建 存储过程job
declare
job binary_integer;
begin
dbms_job.submit(job => job,
what => 'DELETE_MSG_POTENTIAL_VICTIM();',
next_date => sysdate, -- 立即执行
interval => 'sysdate + 1 / 24' -- 每小时执行
);
commit;
end;
-- 查询 job 任务列表
select * from user_jobs;
select * from dba_jobs
select * from all_jobs
-- 修改job 周期
declare
begin
dbms_job.interval(job => 105, interval => 'sysdate + 1 / 24');
commit;
end;
-- 删除 存储过程 job
declare
begin
dbms_job.remove(job => 106);
commit;
end;
-- 立即执行存储过程 job
declare
begin
dbms_job.run(job => 105);
commit;
end;
select sysdate 当前时间,
sysdate + 1 每天,
sysdate + 1 / 24 每小时,
sysdate + 1 / (24 * 60) 每分钟,
sysdate + 1 / (24 * 60 * 60) 每秒,
sysdate + 7 每周,
trunc(sysdate + 1) 每天午夜12点,
trunc(sysdate + 1) + (8 * 60 + 30) / (24 * 60) 每天早上8点30分,
-- show parameter nls_date_language; 'TUESDAY'
next_day(trunc(sysdate), '星期二') + 12 / 24 每星期二中午12点,
trunc(last_day(sysdate)) + 1 每个月第一天的午夜12点,
trunc(add_months(sysdate + 2 / 24, 3), 'Q') - 1 / 24 每个季度最后一天的晚上11点,
-- 周六 saturday,周日 sunday
trunc(least(next_day(sysdate, '星期六'), next_day(sysdate, '星期日'))) +
(6 * 60 + 10) / (24 * 60) 每周六和周日早上6点10分
from dual;
job 时间设置:
每天定时执行
例如:每天的凌晨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
参考:https://blog.csdn.net/qq_34745941/article/details/99857323
边栏推荐
- Pytoch --- use pytoch to realize u-net semantic segmentation
- Why can't you remember when reading? Why can't you remember- My technology learning methodology
- CorelDRAW Graphics Suite2022免费图形设计软件
- 缓存一致性解决方案——改数据时如何保证缓存和数据库中数据的一致性
- Exposure X8 Standard Version picture post filter PS, LR and other software plug-ins
- Document declaration and character encoding
- There is no prompt for SQL in idea XML, and the dialect setting is useless.
- Social media search engine optimization and its importance
- Message mechanism -- message processing
- 第十六周作业
猜你喜欢
Spring recruitment of Internet enterprises: Kwai meituan has expanded the most, and the annual salary of technical posts is up to nearly 400000
[C language] Dynamic Planning --- from entry to standing up
Yolov5网络修改教程(将backbone修改为EfficientNet、MobileNet3、RegNet等)
云服务器的安全设置常识
Alibaba cloud polkit pkexec local rights lifting vulnerability
Pytorch---使用Pytorch进行鸟类的预测
Thinkphp内核工单系统源码商业开源版 多用户+多客服+短信+邮件通知
Keil compilation code of CY7C68013A
Use a mask to restrict the input of the qlineedit control
Federal learning: dividing non IID samples according to Dirichlet distribution
随机推荐
初识P4语言
Cache consistency solution - how to ensure the consistency between the cache and the data in the database when changing data
C language practice - number guessing game
Www2022 | know your way back: self training method of graph neural network under distribution and migration
One step implementation of yolox helmet detection (combined with oak intelligent depth camera)
Research on the security of ognl and El expressions and memory horse
【c语言】基础篇学习笔记
Spring recruitment of Internet enterprises: Kwai meituan has expanded the most, and the annual salary of technical posts is up to nearly 400000
Which insurance company has a better product of anti-cancer insurance?
【c语言】动态规划---入门到起立
Exposure X8 Standard Version picture post filter PS, LR and other software plug-ins
Feature Engineering: summary of common feature transformation methods
Playing with concurrency: what are the ways of communication between threads?
Thinkphp内核工单系统源码商业开源版 多用户+多客服+短信+邮件通知
Pytoch --- use pytoch to predict birds
Microsoft Research Institute's new book "Fundamentals of data science", 479 Pages pdf
The difference between vectorresize and reverse.
Yolov5网络修改教程(将backbone修改为EfficientNet、MobileNet3、RegNet等)
Binary tree problem solving (1)
如何解决在editor模式下 无法删除物体的问题