ORACLE应用系统中对日志表的倒出备份操作的批处理

对于基于ORACLE数据库系统的应用系统的日志表,会随着时间的推移而增大.做ORACLE的DBA就需要将这些日志表按月份或者一段时间备份,把该表中的数据倒出来(按某日期字段),然后再将此表中已经倒出的记录删除掉.为了做这个功能.我写了一个批处理.

功能就是倒出ORACLE数据库中的表的数据.再将倒出的数据删除.倒出和删除的条件是以计划任务执行时当天的零点零分零秒以前的数据...以下是脚本内容.

@echo off
echo @echo off>a.bat
echo echo %%date%%%%time%%--------------倒出开始^>^>dumpaccess.log>>a.bat
rem echo exp user/password@hostname  file=accesslog%date%%time%.dmp log=accesslog.log tables=t_user_access_log query=\"where access_time < to_date (''%date:~0,10%'',''yyyy-mm-dd'')\">>a.bat
echo echo %%date%%%%time%%--------------倒出结束^>^>dumpaccess.log>>a.bat
echo echo %%date%%%%time%%--------------删除开始^>^>dumpaccess.log>>a.bat
echo delete from user.t_user_access_log where access_time ^< to_date(''%date:~0,10%'',''yyyy-mm-dd'');>del.sql
echo echo %%date%%%%time%%--------------整理开始^>^>dumpaccess.log>>a.bat
echo alter table user.t_user_access_log move;>>del.sql
echo echo %%date%%%%time%%--------------整理结束^>^>dumpaccess.log>>a.bat
echo echo %%date%%%%time%%--------------分析开始^>^>dumpaccess.log>>a.bat
echo analyze table user.t_user_access_log compute statistics;>>del.sql
echo echo %%date%%%%time%%--------------分析结束^>^>dumpaccess.log>>a.bat
echo exit>>del.sql
echo sqlplus -S user/password@hostname  ^<del.sql^>dumpaccess.log>>a.bat
echo echo %%date%%%%time%%--------------删除结束^>^>dumpaccess.log>>a.bat
call a.bat
del del.sql
del a.bat

数据倒出功能是通过EXP命令来做的,删除则是SQL语句.此批处理在客户端为WINDOWS2003.服务端为linux oracle 9.2


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值