时间:2022-02-28来源:www.pcxitongcheng.com作者:电脑系统城
公司内做的项目是工厂内的,一般工厂内数据要求的是实时性,很久之前的数据可以自行删除处理,我们数据库用的oracle,所以就想着写一个脚本来删除,这样的话,脚本不管放在那里使用都可以达到效果
由于服务器是windows,参照Oracle Shell Scripting中,我们写一下windows下的脚本
首先删除数据的sql语句写一下
1 2 3 4 5 |
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; --关闭行迁移 |
这一段相当于
1 2 3 4 5 6 |
SPOOL C:\emp.lst SET LINESIZE 100 SET PAGESIZE 50 SELECT * FROM emp; SPOOL OFF |
所以我们得到了一个新的sql文件,例如C:\emp.sql
1 2 3 4 5 6 7 8 9 10 |
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
1 2 3 4 5 6 |
@ echo off echo 开始删除过期数据并缩容 sqlplus /nolog @C:\emp.sql echo 执行成功 pause exit |
保存之后,执行一下看会不会出现问题,如果不会出现问题,添加一下windows的任务计划程序,或者自己写一个windows服务,定期调用一下这个bat就可以了
linux版本的类似,写法这个连接下面有,写完之后先进行测试,然后使用cron或者其他进行定期调用即可
当然,操作数据库表不局限于定期清理数据,也可以进行报表生成、新表创建等其他操作
到此这篇关于oracle删除超过N天数据脚本的文章就介绍到这了
2023-10-31
Oracle如何编写一个sqlldr实例2023-10-31
Oracle的SQLLDR用法简介2023-10-31
Oracle中的高效SQL编写PARALLEL解析1.Oracle数据库系统结构概述 2.Oracle数据库存储结构 物理存储结构 控制文件 数据文件 重做日志文件 归档日志文件 Oracle数据库逻辑结构 数据块(Data Block) (盘)区(Extent) 段(Segment) 表空间(Tablespace) 本地管...
2023-10-31
windows下的Oracle19c 一、官网下载Oracle19c数据库 二、安装Oracle数据库 1.解压安装包 2.运行setup.exe安装 三、配置 四、安装完Oracle数据库,给scott用户解锁 1.解决Oracle数据库中没有scott账户的问题 2.给scott...
2023-10-31