关于Oracle存储过程和调度器实现自动对数据库过期数据清除的问题
导读:收集整理的这篇文章主要介绍了关于Oracle存储过程和调度器实现自动对数据库过期数据清除的问题,觉得挺不错的,现在分享给大家,也给大家做个参考。 目录简介实现原理建表创建存储过程执行删除...
收集整理的这篇文章主要介绍了关于Oracle存储过程和调度器实现自动对数据库过期数据清除的问题,觉得挺不错的,现在分享给大家,也给大家做个参考。 目录
- 简介
- 实现原理
- 建表
- 创建存储过程
- 执行删除过期数据的存储过程
- 创建Jobs定时器
- 总结
简介
数据库中的某些数据不一定要长期保存,例如:日志等数据、当保存一定时间后,系统允许删除所以系统需要定期删除那些已经过期的数据。
实现原理
1张表(Sys_DBA_config)、1个Job定时器(Job_DBA_AutoRunScript)和2个存储过程(DBA_AUTODELETE、DBA_AUTORUNSCRIPT)实现自动清理不同表中的过期数据。 通过定时器调用存储过程查表判断是否开启过期数据清理功能,如果开启调用数据清理的存储过程。
建表
建立数据库任务配置表,用来管理数据库中那些表需要定期处理。
表格类型
字段名 | TyPE | 非空 | 注解 |
---|---|---|---|
NamE | VArchAR2(200) | ✔ | 任务执行对象名称 |
VALUE | VARCHAR2(200) | ✔ | 设置保存时间(天) |
TYPE | VARCHAR2(200) | ✔ | 执行类型 |
ISRUN | NUMBER(1,0) | ✔ | 是否执行 |
REMARK | VARCHAR2(200) | 对应表中判断时间的字段 | |
COLUMNTYPE | VARCHAR2(200) | 字段类型 |
建表语法
create table SYS_DBA_CONFIG( NAME VARCHAR2(200) not null, value VARCHAR2(200) not null, type VARCHAR2(200) not null, REMARK VARCHAR2(200) not null ISRUN NUMBER(1) not null, COLUMNTYPE VARCHAR2(200));
数据展示
表中的数据有两种:
- 存储过程是否启用
- 表格设置保存时间
创建存储过程
判断系统是否启动定期清除功能的存储过程
根据类型和是否启用查找删除数据的存储过程
CREATE OR REPLACE PROCEDURE xxx."DBA_AUTORUNSCRIPT" AS /******************************************************* 功能:定期运行指定脚本V1.0 说明:SQL语句从配置表SYS_DBA_CONFIG读取 ********************************************************/ v_Name VARCHAR2(500); --sql语句变量 v_Value VARCHAR2(250); --Sql语句变量 CURSOR CS IS SELECT UPPER(Name),VALUE From SYS_DBA_CONFIG WHERE LOWER(TYPE)='auto_run_script' AND ISRUN = 1; BEginOPEN CS; LOOPFETCH CS INTO v_Name, v_Value; --获得当前记录的数据 EXIT WHEN CS%NOTFOUND; dbms_output.put_line('执行脚本('||v_Name||'):'||v_Value); EXECUTE IMMEDIATE ('BEGIN '||v_Name||'; COMMIT; END; '); END LOOp; END DBA_AutoRunScript;
执行删除过期数据的存储过程
根据对应的表中的对应字段和当前时间比较,如果时间大于对应的保存时间天数,删除数据。
CREATE OR REPLACE PROCEDURE xxx."DBA_AUTODELETE" AS /******************************************************* 功能:根据保留天数删除数据V1.0 说明:表名称、保存天数从配置表SYS_DBA_CONFIG读取 ********************************************************/ v_name varchar2(250); --对应的表名 v_remark varchar2(250); --对应的表字段 v_value number(10); --表对应的表数据天数 v_endTime date; --清除的具体时间 v_sql varchar2(250); v_columntype varchar2(20); CURSOR CS IS SELECT Name,VALUE,remark,columntype From SYS_DBA_CONFIG WHERE LOWER(TYPE)='auto_delete_table' AND ISRUN=1; BEGINOPEN CS; LOOPFETCH CS INTO v_name, v_value,v_remark,v_columntype; --获得当前记录的数据 EXIT WHEN CS%NOTFOUND; dbms_output.put_line('删除的表名:' || v_name||' 保留天数:'||v_value); v_endTime:=TRUNC(SYSDATE- v_value); if v_columntype='DATE' then v_sql := 'delete from ' || v_name||' where '|| v_remark||' TRUNC(SYSDATE- '||v_value||')' ; dbms_output.put_line('删除的sql:' || v_sql); else v_sql := 'delete from ' || v_name||' where to_date('||v_remark||',''yyyy-mm-dd hh24:mi:ss'') TRUNC(SYSDATE- '||v_value||')'; dbms_output.put_line('删除的sql:' || v_sql); end if; begin execute immediate v_sql; end; END LOOP; END DBA_AutoDelete;
创建Jobs定时器
通过定时器启动判断系统是否启动定期清除功能的存储过程,然后存储过程再调用删除数据的存储过程完成数据清除。
begin dbms_scheduler.create_job ( job_name => 'Job_DBA_AutoRunScript', job_type => 'PLSQL_BLOCK', job_action => 'begin DBA_AutoRunScript; end; ',repeat_interval => 'FREQ=DaiLY; BYHOUR=3; byminute=30', enabled => true); end;
@L_126_13@
总结
后端可以只通过维护SYS_DBA_CONFIG表来维护数据库的过期数据清除管理,不需要后端去处理删除数据的业务逻辑。
到此这篇关于oracle存储过程和调度器实现自动对数据库过期数据清除的文章就介绍到这了,更多相关Oracle实现自动对数据库过期数据清除内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
您可能感兴趣的文章:- oracle通过存储过程上传list保存功能
- oracle 存储过程返回 结果集 table形式的案例
- 解决PL/SQL修改Oracle存储过程编译就卡死的问题
- Oracle如何批量将表中字段名全转换为大写(利用简单存储过程)
- Spring boot调用Oracle存储过程的两种方式及完整代码
- oracle调试存储过程的过程详解
- Oracle如何使用PL/SQL调试存储过程
- Oracle存储过程案例详解
声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!
若转载请注明出处: 关于Oracle存储过程和调度器实现自动对数据库过期数据清除的问题
本文地址: https://pptw.com/jishu/631627.html