我写了个Oracle数据库自动备份脚本,执行后只有log文件,没有dmp文件,在线等。bat文件内容如下:
@echooffecho================================================echoWindows环境下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 USER=system
set PASSWORD=123
set DATABASE=db
::创建备份目录。
if not exist "D:\数据库备份\backup\data" mkdir D:\数据库备份\backup\data
if not exist "D:\数据库备份\backup\log" mkdir D:\数据库备份\backup\log
set DATADIR=D:\数据库备份\backup\data
set LOGDIR=D:\数据库备份\backup\log
exp %USER%/%PASSWORD%@%DATABASE% full=y file=%DATADIR%\%BACKUPDATE%.DMP log=%LOGDIR%\%BACKUPDATE%.log
::删除7天前的备份。
forfiles /p "%DATADIR%" /s /m *.* /d -20 /c "cmd /c del @path"
forfiles /p "%LOGDIR%" /s /m *.* /d -20 /c "cmd /c del @path"
exit 展开
echo ================================================
echo Windows环境下Oracle数据库的自动备份脚本
echo 1. 使用当前日期命名备份文件。
echo 2. 自动删除7天前的备份。
echo ================================================
::以“YYYYMMDD”格式取出当前时间。
set BACKUPDATE=%date:~0,4%%date:~5,2%%date:~8,2%
::设置用户名、密码和要备份的数据库。
set USER=system
set PASSWORD=123
set DATABASE=db
::创建备份目录。
if not exist "D:\数据库备份\backup\data" mkdir D:\数据库备份\backup\data
if not exist "D:\数据库备份\backup\log" mkdir D:\数据库备份\backup\log
set DATADIR=D:\数据库备份\backup\data
set LOGDIR=D:\数据库备份\backup\log
exp %USER%/%PASSWORD%@%DATABASE% full=y file=%DATADIR%\%BACKUPDATE%.DMP log=%LOGDIR%\%BACKUPDATE%.log
::删除7天前的备份。
forfiles /p "%DATADIR%" /s /m *.* /d -20 /c "cmd /c del @path"
forfiles /p "%LOGDIR%" /s /m *.* /d -20 /c "cmd /c del @path"
exit 展开
3个回答
展开全部
大致看了下,没发现你的批处理有明显问题。
那就简单说下排查思路。
1、既然问题出在备份上,就先不要理会删除备份的问题。
2、相信你写批处理以前应该手工输入exp命令成功备份过。
3、把 exp那句输出到文本或批处理文件如下,用记事本打开backdb.txt看看与你成功备份的手输命令有和不同,然后做相应修改即可。
exp改为:
echo exp %USER%/%PASSWORD%@%DATABASE% full=y file=%DATADIR%\%BACKUPDATE%.DMP log=%LOGDIR%\%BACKUPDATE%.log>backdb.txt
追问
log文件里 显示 备份成功了 就是在D:\数据库备份\backup\data里没有dmp文件
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询