最近在使用oracle,本人经常没心,担心数据丢失,所以只能通过各种方式来减少丢失的概率。于是研究了一下oracle数据库备份,其实也算不上研究了,就是百度查找资料然后自己实际操作呗。下面把步骤总结一下。
目录:
一,Windows下的oracle自动备份
二,Ubuntu下的oracle自动备份
一、Windows下oracle 自动备份
1,系统:Windows7
2,建立.bat执行文件
3,建立定时器任务,定时执行
4,向数据库导入dmp文件
下面是语句,直接新建一个文本文档,文件类型为.bat,然后复制粘贴过去即可。
@echo off
echo ================================================
echo Windows环境下Oracle数据库的自动备份脚本
echo 1. 使用当前日期命名备份文件。
echo 2. 自动删除7天前的备份。
echo ================================================
::以“YYYYMMDD”格式取出当前时间。
set BACKUPDATE=%date:~0,4%%date:~5,2%%date:~8,2%%Time:~0,2%%Time:~3,2%%Time:~6,2%
::创建备份目录。
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
set mydate=%date:~0,4%%date:~5,2%%date:~8,2%%Time:~0,2%
exp userid='ADMIN/kanggw@OracleOrcl' file=%DATADIR%\data_%BACKUPDATE%.dmp log=%LOGDIR%\log_%mydate%.log
::删除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
imp BACKUPS/kanggw@OracleOrcl file='D:\backup\data\data_20160325161222.dmp' full=y
其中:@sid是服务名,如果不知道可以在开始里输入:net ,打开net manager 查看</span>
注:如果有时我