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