基于Windows操作系统的oracle数据库定时自动备份

一:创建备份dmp文件及日志路径


dmp文件路径:C:\db_bak\files

日志路径:C:\db_bak\logs




二:创建自动备份批处理文件

   2.1 创建记事本text文件


复制以下内容到记事本中

@echo off
echo ================================================ 
echo  Windows环境下Oracle数据库的自动备份脚本
echo  1. 使用当前日期命名备份文件。
echo  2. 自动删除30天前的备份。
echo ================================================
::以“YYYYMMDD”格式取出当前时间。
set BACKUPDATE=%date:~0,4%%date:~5,2%%date:~8,2%
set CURTIME=%time:~0,2%
REM 小时数如果小于10,则在前面补0
if "%CURTIME%"==" 0" set CURTIME=00
if "%CURTIME%"==" 1" set CURTIME=01
if "%CURTIME%"==" 2" set CURTIME=02
if "%CURTIME%"==" 3" set CURTIME=03
if "%CURTIME%"==" 4" set CURTIME=04
if "%CURTIME%"==" 5" set CURTIME=05
if "%CURTIME%"==" 6" set CURTIME=06
if "%CURTIME%"==" 7" set CURTIME=07
if "%CURTIME%"==" 8" set CURTIME=08
if "%CURTIME%"==" 9" set CURTIME=09
set CURTIME=%CURTIME%%time:~3,2%%time:~6,2%
 
::设置数据库用户名、密码和要备份的数据库。


set USER=BSQAM1
set PASSWORD=BSQAM1
set DATABASE=orcl


::创建备份目录。
if not exist "C:\db_bak\files\%BACKUPDATE% "     mkdir C:\db_bak\files\%BACKUPDATE%
if not exist "C:\db_bak\logs\%BACKUPDATE% "      mkdir C:\db_bak\logs\%BACKUPDATE%
set DATADIR=C:\db_bak\files\%BACKUPDATE%
set LOGDIR=C:\db_bak\logs\%BACKUPDATE%
exp %USER%/%PASSWORD%@%DATABASE%  file=%DATADIR%\%USER%_%BACKUPDATE%%CURTIME%.dmp log=%LOGDIR%\log_%BACKUPDATE%%CURTIME%.log
::删除30天前的备份。可以修改删除日期
forfiles /p "%DATADIR%" /s /m *.* /d -30 /c "cmd /c del @path"
forfiles /p "%LOGDIR%" /s /m *.* /d -30 /c "cmd /c del @path"
exit


2.2 把text文件后缀改为bat格式形成批处理文件



三 创建定时任务 

 3.1 创建基本任务


3.2 进行相关设置

  创建基本任务》》触发器》》操作》》完成


如图进行相关设置即可 最后点击完成








完成后查看任务:




到此为止数据库定时自动备份完成 

注意:可以修改任务开始时间进行相关测试




   




  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 很高兴为您服务,要设置定时备份Oracle数据库,可以通过Oracle Recovery Manager (RMAN)来实现。RMAN提供了一个持久的环境,可以用来创建定期的备份,也可以用来备份数据库。另外,您还可以使用Scheduled Tasks来设置定时任务,它可以让您定期执行RMAN备份命令。 ### 回答2: Oracle数据库可以使用RMAN(Recovery Manager)工具来设置定时备份。以下是一个设置定时备份的步骤示例: 1. 首先,登录到数据库服务器上。 2. 打开命令行窗口或终端,并使用sysdba权限以管理员身份登录到数据库。命令如下: ``` sqlplus / as sysdba ``` 3. 创建一个新的备份脚本文件,例如`backup_script.rman`,用于指定备份设置。可以使用文本编辑器创建该文件。例如,使用vi编辑器创建: ``` vi backup_script.rman ``` 4. 在备份脚本文件中添加以下内容,来定义备份设置: ``` CONFIGURE DEFAULT DEVICE TYPE TO disk; CONFIGURE DEVICE TYPE disk PARALLELISM 2 BACKUP TYPE TO COMPRESSED BACKUPSET; CONFIGURE CONTROLFILE AUTOBACKUP ON; CONFIGURE CONTROLFILE AUTOBACKUP FORMAT FOR DEVICE TYPE DISK TO '/path/to/backup/%F'; CONFIGURE CHANNEL DEVICE TYPE disk FORMAT '/path/to/backup/full_%d_%T_%U'; CONFIGURE RETENTION POLICY TO REDUNDANCY 2; ``` 上述备份设置可以根据实际需求进行修改。例如可以修改备份路径、备份文件名格式、备份类型等。 5. 保存并退出备份脚本文件。 6. 执行以下命令来执行备份: ``` rman target / RMAN> @/path/to/backup_script.rman ``` 这将加载备份脚本文件,并根据其中的备份设置执行备份操作。 7. 运行以上命令后,数据库将按照设定的定时任务执行备份操作。可以使用类似于crontab的定时任务工具,例如,使用crontab来定期运行备份命令: ``` crontab -e ``` 在打开的编辑器中添加以下内容,以每天晚上8点执行备份: ``` 0 20 * * * /path/to/oracle_home/bin/rman target / @/path/to/backup_script.rman ``` 保存并退出编辑器。 通过以上步骤,在Oracle数据库中就可以设置定时备份,确保数据库数据的安全性和可恢复性。 ### 回答3: 要设置Oracle数据库定时备份,可以采用以下步骤: 1. 创建备份脚本:首先,需要编写一个脚本来执行备份操作。该脚本可以使用Oracle提供的工具,比如RMAN (Recovery Manager),来实现备份功能。脚本需要指定备份的目标数据库以及备份文件的存储位置。 2. 创建定时任务:接下来,在操作系统创建一个定时任务,以便在指定的时间来执行备份脚本。可以使用Cron工具(在Unix/Linux系统上)或者Task Scheduler工具(在Windows系统上)来创建定时任务。设置定时任务时,可以指定备份脚本的执行时间、间隔和执行频率。 3. 测试备份脚本:在设置定时任务之前,应该先手动执行备份脚本进行测试,确保备份操作能够正常执行并生成有效的备份文件。通过验证备份脚本的正确性,可以确保自动定时备份的可靠性。 4. 设置日志和报警:为了能够监控备份操作的执行情况,可以在备份脚本中添加日志记录功能,将备份操作的日志信息保存到指定的文件中。另外,可以设置报警机制,当备份操作出现异常或失败时,及时发送报警通知给相关负责人。 5. 监控和维护:在备份任务开始执行之后,需要定期监控备份操作的运行情况,确保备份文件的完整性和一致性。同时,还需要保持数据库的健康状况,及时处理任何可能影响备份操作的故障或问题。 总结起来,设置Oracle数据库定时备份即意味着编写备份脚本、创建定时任务、测试脚本、设置日志和报警,并进行监控和维护。这样可以确保数据库的重要数据能够按时备份,并且备份过程能够可靠运行。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值