暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

oracle删除超过N天数据脚本

原创 数据库新手-ray 2022-04-15
395

公司内做的项目是工厂内的,一般工厂内数据要求的是实时性,很久之前的数据可以自行删除处理,我们数据库用的oracle,所以就想着写一个脚本来删除,这样的话,脚本不管放在那里使用都可以达到效果

由于服务器是windows,参照Oracle Shell Scripting中,我们写一下windows下的脚本

首先删除数据的sql语句写一下

Copy


DELETE FROM tablename WHERE createdtime<TRUNC(SYSDATE)-59; --删除59天前的数据


commit; --提交事务


alter table tablename enable row movement; --数据删除之后会产生很多空行,打开行移动,移动之后rowid会发生变化


alter table tablename shrink space; --连同索引一起压缩,解决delete语句造成的空间未释放问题


alter table tablename disable row movement; --关闭行迁移

这一段相当于

Copy


SPOOL C:\emp.lst


SET LINESIZE 100


SET PAGESIZE 50


SELECT *


FROM emp;


SPOOL OFF

所以我们得到了一个新的sql文件,例如C:\emp.sql

Copy


CONNECT scott/tiger


--开始删除


DELETE FROM tablename WHERE createdtime<TRUNC(SYSDATE)-59;


commit;


alter table tablename enable row movement;


alter table tablename shrink space;


alter table tablename disable row movement;


--结束删除


--如果删除多个表,可以将上面语句复制一下,tablename和where条件修改一下就可以了


EXIT;

然后创建一个文件C:\get_emp.bat

Copy


@echo off


echo 开始删除过期数据并缩容



sqlplus /nolog @C:\emp.sql



echo 执行成功


pause


exit

保存之后,执行一下看会不会出现问题,如果不会出现问题,添加一下windows的任务计划程序,或者自己写一个windows服务,定期调用一下这个bat就可以了

linux版本的类似,写法这个连接下面有,写完之后先进行测试,然后使用cron或者其他进行定期调用即可

当然,操作数据库表不局限于定期清理数据,也可以进行报表生成、新表创建等其他操作

「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论