我写了个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
展开
 我来答
sudoku52
推荐于2016-08-15 · TA获得超过7万个赞
知道大有可为答主
回答量:1.2万
采纳率:82%
帮助的人:4748万
展开全部

大致看了下,没发现你的批处理有明显问题。

那就简单说下排查思路。

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文件
UltimAteNoOB
2018-05-24
知道答主
回答量:1
采纳率:0%
帮助的人:851
展开全部
建议检查一下C盘windows目录下面system32或者syswow64文件夹~
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
faraway_xj
2015-07-24 · TA获得超过2675个赞
知道大有可为答主
回答量:2482
采纳率:0%
帮助的人:1309万
展开全部
log里记录的什么错误
追问
log和手动备份成功的log文件里的一样
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 2条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式