oracle数据库定时备份、定时删除

写在前面:

        在实际的工作中,很多数据库没有条件做热备,这时候就需要由运维人员,自行定期对数据库进行备份。

                                                                                                        ——古太郎 | CSDN

一、原理

    写一个数据库备份、删除脚本,加入到windows任务计划里,定期定时执行即可;

二、步骤

1、新建txt文档,输入如下“oracle数据库定时备份、删除脚本”内容,如图所示:

@echo off   
echo ================================================   
echo  Windows环境下Oracle数据库的自动备份脚本  
echo  1. 使用当前日期命名备份文件。  
echo  2. 自动删除7天前的备份。  
echo ================================================  
::以“YYYYMMDD”格式取出当前时间。  
set BACKUPDATE=%date:~0,4%%date:~5,2%%date:~8,2%  
::设置用户名、密码和要备份的数据库。  
set USERA=dwzszf
set PASSWORD=dwzszf
set SID=orcl
::创建备份目录。  
if not exist "C:\oraclebackup\data"       mkdir C:\oraclebackup\data  
if not exist "C:\oraclebackup\log"        mkdir C:\oraclebackup\log  
set DATADIR=C:\oraclebackup\data  
set LOGDIR=C:\oraclebackup\log  
exp %USERA%/%PASSWORD%@%SID%  file=%DATADIR%\%BACKUPDATE%.dmp 
::删除7天前的备份。  
forfiles /p "%DATADIR%" /s /m *.* /d -7 /c "cmd /c del @path"  
forfiles /p "%LOGDIR%" /s /m *.* /d -7 /c "cmd /c del @path"  
exit  

脚本说明:

@:表示执行脚本时,@行之后的内容不显示;
echo off:表示此行和之后的内容不显示;
echo:表示执行脚本时,此行的内容执行脚本显示出来;
:::注释,类似于sql语句的--;
%date:~0,4%%date:~5,2%%date:~8,2% :WINDOWS的时间格式是2017/09/07,所以意思就是从左往右数第0个之后,取4位,即2017;从左往右数第5个之后,取2位,即09,从左往右数第8个之后,取2位,即07,最终备份文件名就是20170907.dmp;

题外话,若不想自动备份在本地服务器(A),比如我想备份在别的服务器上(B),那这时,我只要保证B能连上A的数据库,就可以设置SID=192.168.X.X/orcl,这时候就实现了A的数据每天自动备份在B服务器上,间接实现了异地备份~

2、另存为.bat格式,如图所示:

3、window添加定时任务

这个就不说了!

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值