windows计划任务+批处理文件实现oracle数据库的定时备份与恢复

简介: 1.  备份: PS:2014-1-15 如果导出的dmp数据文件不大的话,就直接每天导出好了,不要只保存七天的数据。然后顶起通过winrar对文件进行打包,我发现dmp文件的压缩包还是很高的。 那么就需要考虑在导出的dmp文件末尾加上日期了。

1.  备份:

PS:2014-1-15

如果导出的dmp数据文件不大的话,就直接每天导出好了,不要只保存七天的数据。然后顶起通过winrar对文件进行打包,我发现dmp文件的压缩包还是很高的。

那么就需要考虑在导出的dmp文件末尾加上日期了。bat脚本里面有date和time的函数,通过以下函数我们就可以得到想要的日期了。如果要求日期是以"-"结束,需要设定日期的格式为YYYY-M-D,而不是YYYY/M/D才可以。

C:\Users\User>echo %date:~0,10%-%time:~0,2%-%time:~3,2%-%time:~6,2%
2014-01-15-15-52-43

得到日期格式以后,我们的导出脚本就可以修改为

exp xuwei/xuwei@orcl file=f:\mydata_mytest\oradata_%date:~0,10%-%time:~0,2%-%time:~3,2%-%time:~6,2%.dmp log=f:\mydata_mytest\oradata_%date:~0,10%-%time:~0,2%-%time:~3,2%-%time:~6,2%.log

然后创建计划任务每天都执行一次即可。

PS:2014-4-3

今天发现以上脚本不能执行,这是因为%time%有一个问题, 时间中的小时, 不足两位不会自动补0(系统中不足两位时, 是补空格的, 所以我们判断到时空格, 用0来替换就可以了),具体参考:http://blog.csdn.net/bagboy_taobao_com/article/details/7198578 。修改以后的脚本如下:

复制代码
@echo off
set NLS_LANG= AMERICAN_AMERICA.AL32UTF8
set hour=%time:~,2%
if "%time:~,1%"==" " set hour=0%time:~1,1%
set temp=%date:~0,4%-%date:~5,2%-%date:~8,2%-%hour%-%time:~3,2%-%time:~6,2%
exp BAOL4Dev_CGN/BAOL4Dev_CGN@env1d file=D:\db_backup\daily_backup\oradata_%temp%.dmp log=D:\db_backup\daily_backup\oradata_%temp%.log
pause
复制代码

PS:2014-06-19对于时间格式的判断

http://www.sql9.com/?id=86

http://bbs.csdn.net/topics/110143577

上面的日期格式还不是最优化的,因为%date:~0,10%的输出结果可能是2014/06/19,也有可能是2014-06-19,这取决于系统对于日期格式的设定。所以对于data不能直接取全部字段,而是要将年月日单独取出来。

C:\Users\wei.xu>echo %date:~0,4%%date:~5,2%%date:~8,2%%time:~0,2%%time:~3,2%%time:~6,2%
20140619170757

1.1.  创建database_exp.bat批处理文件

首先首先创建七天的dmp和log空文件,然后创建一个用于导出数据库的批处理文件,这个脚本能够备份最近七天的数据库,database_ext.bat内如如下所示:

复制代码
del f:\mydata_mytest\oradata7.dmp 
del f:\mydata_mytest\oradata7.log
ren f:\mydata_mytest\oradata6.dmp oradata7.dmp
ren f:\mydata_mytest\oradata5.dmp oradata6.dmp
ren f:\mydata_mytest\oradata4.dmp oradata5.dmp
ren f:\mydata_mytest\oradata3.dmp oradata4.dmp
ren f:\mydata_mytest\oradata2.dmp oradata3.dmp
ren f:\mydata_mytest\oradata.dmp oradata2.dmp
ren f:\mydata_mytest\oradata6.log oradata7.log
ren f:\mydata_mytest\oradata5.log oradata6.log
ren f:\mydata_mytest\oradata4.log oradata5.log
ren f:\mydata_mytest\oradata3.log oradata4.log
ren f:\mydata_mytest\oradata2.log oradata3.log
ren f:\mydata_mytest\oradata.log oradata2.log
exp xuwei/xuwei@orcl file=f:\mydata_mytest\oradata.dmp log=f:\mydata_mytest\oradata.log
复制代码

(ps:2013-8-8)

 

ren f:\mydata_mytest\oradata6.dmp oradata7.dmp 
ren命令第一个是带路径的,第二个参数是不带路径的,表示就在第一个文件的目录下。

 

(ps:2011-12-29)

database_exp.bat解析:上面的批处理语句其实非常简单,就是让七个dmp文件组成一个长度为7的队列,然后每次备份数据库的时候删除队列头部,也就是备份最后的那个oracle7.dmp文件,这个时候oralce6.dmp成为队列头部元素,将oralce6.dmp命名为oracle7.dmp,后面的一次类推。知道最后将oracle.dmp重命名为oracle2.dmp,然后使用exp命令导出数据库文件,导出的文件存放在oracle.dmp文件中。

今天碰到一个问题,就是有一个text.dmp文件,我只想导入这个.dmp文件中的一个表或者是两个表,那么应该如何实现。其实imp命令有一系列的参数,我们可以通过tables这个参数来控制需要导入的数据库表。导入一张表的情况,导入命令如下:

imp username/password@SID file=f:\test.dmp tables=WORKFLOW ignore=y

如果是导入两张或者两张表以上,那么就需要通过括号括起来,导入命令如下:

imp username/password@SID file=f:\test.dmp tables=(EMP,WORKFLOW) ignore=y

1.2.  执行database_ext.bat批处理文件

可以双击这个批处理文件,也可以将这个批处理文件拖到cmd中执行。

2.  恢复

2.1.  建立droptables.sql脚本

这个sql脚本是用来执行数据库存储过程的。droptable.sql的内容如下所示:

execute droptables();
exit

2.2.  创建存储过程       

之所以要执行这个脚本,是为了在恢复数据库之前,首先删除数据库中的所有已存在的表。

droptables存储过程用来删除当前数据库中的所有表,存储过程内容如下所示:

复制代码
CREATE OR REPLACE 
procedure droptables is
v_sql varchar2(2000) ;
CURSOR cur is select table_name from user_tables order by table_name;
begin for rows in cur loop v_sql := 'drop TABLE ' || rows.table_name||' cascade constraints';
dbms_output.put_line(v_sql);
execute immediate v_sql;
end loop;
execute immediate 'purge recyclebin';
end droptables;
复制代码

可以在Sql Developer中创建存储过程,如下图所示:

PS-2014-2-25存储过程的执行

在cmd命令窗口下

execute droptables();
exit

在sql窗口下

begin
droptables();
end;

2.3.  创建imp.bat批处理文件

imp.bat这个批处理文件用于恢复数据,其原理就是将前面备份的dmp数据库文件导入到数据库中。imp.bat内容如下所示:

sqlplus xuwei/xuwei@orcl @f:\mydata_mytest\droptables.sql
imp xuwei/xuwei@orcl file=f:\mydata_mytest\oradata.dmp full=y ignore=y

2.4.  bat文件命名的注意点

上述的两个批处理文件分别命名为database_imp.bat和database_exp.bat,如果命名为imp.bat和exp.bat,双击这两个文件都会出错,而将他们拖拽到cmd命令中则能够正常执行。这是因为批处理文件的文件名不能是命令的单词相同,上述imp和exp都是命令的名字,所以不能用来做bat文件的文件名。

3.  使用Windows任务计划程序

在控制面板中打开计划任务程序,然后按如下图进行计划任务配置。

注意点:如果要是windows系统执行计划任务,那么必须开启计划任务程序的服务,

计划任务程序所对应的服务叫做TaskSchedule,如下图所示:


本文转自xwdreamer博客园博客,原文链接:http://www.cnblogs.com/xwdreamer/archive/2011/07/15/2296980.html,如需转载请自行联系原作者


目录
相关文章
|
14天前
|
Oracle 安全 关系型数据库
【Oracle】使用Navicat Premium连接Oracle数据库两种方法
以上就是两种使用Navicat Premium连接Oracle数据库的方法介绍,希望对你有所帮助!
165 28
|
5天前
|
存储 关系型数据库 MySQL
利用Cron表达式实现MySQL数据库的定时备份
以上就是如何使用Cron表达式和mysqldump命令实现MySQL数据库的定时备份。这种方法的优点是简单易用,而且可以根据需要定制备份的时间和频率。但是,它也有一些限制,例如,它不能备份MySQL服务器的配置文件和用户账户信息,也不能实现增量备份。如果需要更复杂的备份策略,可能需要使用专门的备份工具或服务。
39 15
|
24天前
|
SQL Oracle 关系型数据库
【赵渝强老师】Oracle的闪回数据库
Oracle闪回数据库功能类似于“倒带按钮”,可快速将数据库恢复至 earlier 状态,无需还原备份。本文介绍了闪回数据库的使用方法及实战案例:包括设置归档模式、开启闪回功能、记录SCN号、执行误操作后的恢复步骤等。通过具体 SQL 操作演示了如何利用闪回数据库恢复被误删的用户数据。注意,使用此功能前需确保数据库为归档模式。
|
26天前
|
Oracle 关系型数据库 数据库
【赵渝强老师】Oracle数据库的闪回表
本文介绍了Oracle数据库中的闪回表(Flashback Table)功能,它能够将表的数据快速恢复到特定时间点或系统改变号(SCN),无需备份。文章通过实战示例详细演示了如何使用闪回表恢复数据,包括授权、创建测试表、记录时间与SCN号、删除数据、启用行移动功能、执行闪回操作以及验证恢复结果等步骤。同时,还展示了如何通过触发器禁止插入操作,并在闪回过程中处理触发器的启用问题。文末附有视频讲解,帮助读者更好地理解闪回表的使用方法。
73 10
|
28天前
|
Oracle 关系型数据库 数据库
【赵渝强老师】Oracle数据库的闪回查询
本文介绍了Oracle数据库的闪回查询(Flashback Query)功能及其实际应用。闪回查询通过`AS OF`子句,结合时间戳或SCN号,可查询历史数据状态,帮助分析数据差异。文中通过具体示例演示了如何使用闪回查询:创建测试表、记录当前SCN号、更新数据并提交事务,最后通过闪回查询获取历史数据。附带的视频和代码块详细展示了操作步骤与结果。
|
29天前
|
Oracle 关系型数据库 数据管理
【赵渝强老师】Oracle数据库的闪回技术
在Oracle数据库操作中,难免会遇到误删表或提交错误事务等问题,可能导致数据丢失甚至数据库停止运行。传统解决方法依赖备份恢复,但需提前准备正确备份。为此,Oracle提供了闪回技术,无需备份即可快速恢复数据。它支持7种类型的操作,如闪回查询、版本查询、表恢复等,能有效应对逻辑损坏和用户错误。闪回技术基于还原(undo)数据管理,启用自动管理后可实现高效恢复。
|
1月前
|
关系型数据库 MySQL Java
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
|
1月前
|
关系型数据库 MySQL 数据库连接
docker拉取MySQL后数据库连接失败解决方案
通过以上方法,可以解决Docker中拉取MySQL镜像后数据库连接失败的常见问题。关键步骤包括确保容器正确启动、配置正确的环境变量、合理设置网络和权限,以及检查主机防火墙设置等。通过逐步排查,可以快速定位并解决连接问题,确保MySQL服务的正常使用。
301 82
|
1天前
|
负载均衡 算法 关系型数据库
大数据新视界--大数据大厂之MySQL数据库课程设计:MySQL集群架构负载均衡故障排除与解决方案
本文深入探讨 MySQL 集群架构负载均衡的常见故障及排除方法。涵盖请求分配不均、节点无法响应、负载均衡器故障等现象,介绍多种负载均衡算法及故障排除步骤,包括检查负载均衡器状态、调整算法、诊断修复节点故障等。还阐述了预防措施与确保系统稳定性的方法,如定期监控维护、备份恢复策略、团队协作与知识管理等。为确保 MySQL 数据库系统高可用性提供全面指导。
|
6天前
|
SQL 关系型数据库 MySQL
大数据新视界--大数据大厂之MySQL数据库课程设计:MySQL 数据库 SQL 语句调优方法详解(2-1)
本文深入介绍 MySQL 数据库 SQL 语句调优方法。涵盖分析查询执行计划,如使用 EXPLAIN 命令及理解关键指标;优化查询语句结构,包括避免子查询、减少函数使用、合理用索引列及避免 “OR”。还介绍了索引类型知识,如 B 树索引、哈希索引等。结合与 MySQL 数据库课程设计相关文章,强调 SQL 语句调优重要性。为提升数据库性能提供实用方法,适合数据库管理员和开发人员。

推荐镜像

更多
下一篇
oss创建bucket