oracle删除超过N天数据脚本的方法

 更新时间:2022年02月28日 14:52:25   作者:不辍  
这篇文章主要介绍了oracle删除超过N天数据脚本的方法,本文通过sql语句给大家详细说明讲解,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

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

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

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

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;  --关闭行迁移

这一段相当于

SPOOL C:\emp.lst
SET LINESIZE 100
SET PAGESIZE 50
SELECT *
FROM emp;
SPOOL OFF

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

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

@echo off
echo 开始删除过期数据并缩容
sqlplus /nolog @C:\emp.sql
echo 执行成功
pause
exit

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

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

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

到此这篇关于oracle删除超过N天数据脚本的文章就介绍到这了,更多相关oracle删除数据脚本内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • oracle报错(ORA-00600)问题处理

    oracle报错(ORA-00600)问题处理

    最近在做一个项目,使用的是Oracle数据库,近两天不知道怎么回事,告警日志里总是显示这个错误(ORA-00600:internalerrorcode,arguments:[kcblasm_1],[103],[],[],[],[],[],[])度娘了一下,终于找到解决方式,分享给大家
    2014-08-08
  • Oracle用户密码过期如何修改永不过期

    Oracle用户密码过期如何修改永不过期

    针对不同的业务场景会有不一样的业务需求,oracle的用户密码,生产环境肯定需要定期进行更换,保证安全性,但是也同样会有需求要求oracle用户的密码永远不过期,这篇文章主要给大家介绍了关于Oracle用户密码过期如何修改永不过期的相关资料,需要的朋友可以参考下
    2024-03-03
  • Oracle安装监听器错误的解决方法

    Oracle安装监听器错误的解决方法

    这篇文章给大家介绍了oracle安装监听器错误的解决方法,非常不错,具有参考借鉴价值,需要的朋友参考下吧
    2017-09-09
  • Oracle服务端1521端口无法telnet,服务名未开启监听的解决

    Oracle服务端1521端口无法telnet,服务名未开启监听的解决

    这篇文章主要介绍了Oracle服务端1521端口无法telnet,服务名未开启监听的解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-12-12
  • Oracle之TO_DATE用法详解

    Oracle之TO_DATE用法详解

    这篇文章主要介绍了Oracle之TO_DATE用法详解,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-08-08
  • Oracle数据加密方法分析

    Oracle数据加密方法分析

    这篇文章主要介绍了Oracle数据加密方法,实例分析了Oracle基于md5算法的数据加密技巧,需要的朋友可以参考下
    2016-09-09
  • 判定一个字符串是否为有效时间的函数

    判定一个字符串是否为有效时间的函数

    判定时间是否有效的函数,为有效时间则返回1,不是有效时间则返回0,需要的朋友可以参考下
    2014-07-07
  • Oracle数据库之PL/SQL使用流程控制语句

    Oracle数据库之PL/SQL使用流程控制语句

    这篇文章介绍了Oracle数据库之PL/SQL使用流程控制语句的方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-05-05
  • Win11系统下Oracle11g数据库下载与安装使用详细教程(图解)

    Win11系统下Oracle11g数据库下载与安装使用详细教程(图解)

    Oracle11g是Oracle公司出的一个比较轻量版的数据库,在window系统上安装比较方便,这篇文章主要给大家介绍了关于Win11系统下Oracle11g数据库下载与安装使用的相关资料,需要的朋友可以参考下
    2023-12-12
  • Oracle dbca时报:ORA-12547: TNS:lost contact错误的解决

    Oracle dbca时报:ORA-12547: TNS:lost contact错误的解决

    这篇文章主要给大家介绍了关于Oracle在dbca时报:ORA-12547: TNS:lost contact错误的解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面来一起看看吧。
    2017-11-11

最新评论