Oracle数据库定时备份及还原方法

本文详细介绍Oracle数据库的备份与还原流程,包括本地与远程连接、目录创建与权限设置、数据备份与还原命令,以及定时备份与压缩脚本示例。适用于数据库管理员进行日常维护与数据安全管理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

oracle数据库定时备份及还原方法

一、oracle数据备份

1、找到电脑右下方开始--运行,输入cmd,进入dos命令窗口。

2、输入sqlplus system/密码@orcl (一般管理员登录)--------连接本机oracle数据库

输入 sqlplus system/密码@IP:端口/orcl (一般管理员登录)--------连接非本机oracle数据库

https://i-blog.csdnimg.cn/blog_migrate/96a122bcb5a1ce22c0b8cb29f7511be1.png

3、创建一个dmp的目录,输入create directory dpdata1 as 'E:\temp\dmp'; 

https://i-blog.csdnimg.cn/blog_migrate/2b7561a0acb5e03437377937929f7df4.png

4、查询是否有此目录,select * from dba_directories;

https://i-blog.csdnimg.cn/blog_migrate/8665b45b9b3a8c37bb4db3d1cd62e4ae.png

5、在E盘下新建E:\temp\dmp目录

6、赋于要导出数据表的所属用户权限,grant read,write on directory dpdata1 to 用户名;,授权成功以后输入exit 退出sql。

https://i-blog.csdnimg.cn/blog_migrate/daee10aaeb35dc5a6441bf9553083794.png

7、开始数据备份,expdp system/密码@orcl directory=dpdata1 dumpfile=文件名.dmp logfile=文件名.log schemas=用户名https://i-blog.csdnimg.cn/blog_migrate/fb49d9367cd6772e0f6f89eefe46af8a.png

8、目录E:\temp\dmp下面可以看到备份文件,备份完成。

https://i-blog.csdnimg.cn/blog_migrate/1e4b8591dc1fdd2a3ec1f6010e1e7f72.png

二、oracle数据还原

1、找到电脑右下方开始--运行,输入cmd,进入dos命令窗口。

2、输入sqlplus system/密码@orcl (一般管理员登录)--------连接本机oracle数据库

3、删除user,输入 drop user 用户名 cascade;

https://i-blog.csdnimg.cn/blog_migrate/bc2ea1322f8ecd107ea432e42d4b17c9.png

4、导入还原数据,输入 impdp system/密码@orcl directory=dpdata1 dumpfile=dmp文件名 logfile=log文件名 schemas=用户名;        还原完成。

https://i-blog.csdnimg.cn/blog_migrate/ca36ad81f9876505c39be9d8a143260e.png

https://i-blog.csdnimg.cn/blog_migrate/7ca6905b8640b7ac19e2b8464b009b2b.png

5、在plsql或者其他oracle检查数据完整性,脚本如下:

select t.table_name , t.num_rows from user_tables t order by t.num_rows desc

三、定时备份及压缩

1.备份及压缩

  1. @echo off
  2.  
  3. set backupfile=f_database_%date:~0,4%-%date:~5,2%-%date:~8,2%.dmp
  4. set logfile=f_database_%date:~0,4%-%date:~5,2%-%date:~8,2%.log
  5.  
  6. delete 1days files
  7.  
  8. forfiles /p "E:\temp\dmp" /d -1  /c "cmd /c echo deleting @file ... && del /f @path"
  9.  
  10. cd F:\temp\dmp
  11.  
  12. backup schemas
  13. set backupfile=IRRIG_SOUTH_DEV_%date:~0,4%-%date:~5,2%-%date:~8,2%.dmp
  14. set logfile=IRRIG_SOUTH_DEV_%date:~0,4%-%date:~5,2%-%date:~8,2%.log
  15. expdp IRRIG_SOUTH_DEV/IRRIG_SOUTH_DEV@orcl directory=dpdata1  dumpfile=%backupfile%  logfile=%logfile% schemas=IRRIG_SOUTH_DEV parallel=4
  16.  
  17.  
  18. rem 压缩程序目录
  19. set zipDir= C:\Program Files (x86)\HaoZip\HaoZip.exe
  20.  
  21. echo 正在设置压缩包日期...
  22. set mydate=%date:~5,2%%date:~8,2%
  23.  
  24. echo 正在压缩...
  25. %zipDir% a -m5 -t %bakDir%\ora_data_%mydate%.zip %bakDir%\ora_data_%mydate%.dmp %bakDir%\ora_log_%mydate%.log

 

2.定时备份

  1. @ECHO OFF
  2. schtasks /create /tn IRRIG_SOUTH_DEV数据库定时备份 /tr "E:\temp\IRRIG_SOUTH_DEV.bat" /sc daily /st 00:00:00 /ru "system"
  3. PAUSE
  4. EXIT
  5. windows每晚自动运行数据库备份bat

 

 

1、提供了oracle数据库备份脚本,导出dmp文件 2、定时任务由操作系统提供的支持,在操作系统中设置定时任务,由操作系统定期执行脚本 3、补充。压缩包脚本有点问题,不能删除旧的备份文件。需要自动删除历史备份文件请用最新脚本: @echo off @echo ================================================ @echo windows环境下Oracle数据库的自动备份脚本 @echo 说明:启动备份时,需要配置以下变量 @echo 1、BACKUP_DIR 指定要备份到哪个目录 @echo 2、ORACLE_USERNAME 指定备份所用的Oracle用户名 @echo 3、ORACLE_PASSWORD 指定备份所用的Oracle密码 @echo 4、ORACLE_DB 指定备份所用的Oracle连接名 @echo 5、BACK_OPTION 备份选项,可以为空,可以为full=y,可以为owner=a用户,b用户 等等.... @echo 6、RAR_CMD 指定RAR命令行压缩工具所在目录 @echo ================================================ rem 以下变量需要根据实际情况配置 set BACKUP_DIR=D:\tools\oracle_bak\backup230 set ORACLE_USERNAME=PLATADMIN set ORACLE_PASSWORD=123456 set ORACLE_DB=ORCL set BACK_OPTION=owner=PLATADMIN set RAR_CMD="D:/Program Files/WinRAR/Rar.exe" rem for /f "tokens=1,2" %%a in ('date/t') do set TODAY=%%a rem set BACK_NAME=%ORACLE_DB%_%TODAY%(%time:~0,2%时%time:~3,2%分)_ set BACK_NAME=%Date:~0,4%%Date:~5,2%%Date:~8,2%%Time:~0,2%%Time:~3,2%%Time:~6,2% set BACK_FULL_NAME=%BACKUP_DIR%/%BACK_NAME% rem 开始备份 exp %ORACLE_USERNAME%/%ORACLE_PASSWORD%@%ORACLE_DB% %BACK_OPTION% file="%BACK_FULL_NAME%.dmp" log="%BACK_FULL_NAME%exp.log" rem 压缩并删除原有文件 %RAR_CMD% a -df "%BACK_FULL_NAME%back.rar" "%BACK_FULL_NAME%.dmp" "%BACK_FULL_NAME%exp.log" rem 删除15天前的备份文件 forfiles /p %BACKUP_DIR% /s /m *.rar /d -15 /c "cmd /c del @file"
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值