Oracle基础 数据库备份和恢复
一、为什么需要数据备份
造成数据丢失的主要原因:
1、介质故障。
2、用户的错误操作。
3、服务器的彻底崩溃。
4、计算机病毒。
5、不可预料的因素。
Oracle中故障类型分为以下4种。
1、语句故障:
执行SQL语句过程发生的逻辑故障可导致语句故障。如果用户编写的SQL语句无效,就会发生语句故障。Oracle可自我修复语句故障,撤销语句产生的而印象,并将控制权交给应用程序。
2、用户进程故障
当用户程序出错而无法访问Oracle数据库时,就会发生用户进程故障。用户进程故障只会导致当前用户无法操作数据库,但不会印象其他用户进程,当用户进程出现故障时,进程监控程序(PMON)会自动执行进程恢复。
3、实例故障
当Oracle 数据库实例由于硬件或软件问题而无法继续运行时,就会发生实例故障。硬件问题包括意外断电,而然间问题可能是服务器操作系统崩溃。如果发现实例故障,Oracle会自动完成实例修复。实例修复将数据库恢复到与故障之前的事务一致状态,Oracle会自动回滚未提交的数据。
4、介质故障
介质故障是当一个数据库文件或者磁盘不能读或者不能写时出现的故障。
二、备份
备份就是把创建一个数据库副本到磁盘。从不同角度分类如下:
1、从物理角度与逻辑角度分类:
(1)物理备份:对数据库操作系统的物理文件(如数据文件、控制文件和日志文件等)的备份。物理备份又可分为脱机备份(冷备份)和联机备份(热备份),前者是在关闭数据库的时候进行的,后者对运行在归档日志方式的数据库进行备份。
(2)逻辑备份:对数据库逻辑组件(如表和存储过程等数据对象)的备份。
2、从数据库的备份策略角度分类:
(1)完全备份:每次对数据进行完整备份。
(2)增量备份:值有那些在上次完全备份或者增量备份后备修改的文件才会被备份。优点是备份数据量小,需要的时间短,缺点是恢复的时候需要依赖之前的备份记录,出问题的风险较大。例如:如果在星期一进行完全备份,在星期二至星期五进行增量备份。如果星期五数据被破坏了,则数据恢复需要星期一的完全备份和从星期二至星期五的所有增量备份。
(3)差异备份:备份那些从上次完全备份之后被修改过得文件。因此从差异备份中恢复数据的时间长短,因此只需要两份数据(最后一次完全备份和最后一次差异备份),缺点是每次备份的时间较长。例如:如果在星期一进行完全备份,在星期二到星期五进行了差异备份,如果星期五数据被破坏了,则数据恢复只需要星期的完全备份和星期四的差量备份。
增量备份和差异备份的区别:增量备份需要保留所有增量备份的数据;差异备份只需要保留最后一次差异备份的数据。
三、恢复
恢复就是发生故障后,利用已备份的数据文件或控制文件,重新建立一个完整的数据库。恢复分为两种类型:
1、实例恢复:当Oracle实例出现失败后,Oracle自动进行的恢复。
2、介质恢复:当存放数据库的介质出现故障时所做的恢复。介质恢复又分为完全恢复和不完全恢复。
完全恢复:将数据库恢复到数据库失败时的状态。
不完全恢复:将数据库恢复到数据库失败前的某一时刻的状态。
四、导出
(一)使用数据泵技术:
1、expdp的导出方式:
1)数据库方式:整个数据被导入到操作系统文件中。
2)用户模式:导出一个或者多个用户下的所有数据和元数据。
3)表方式:到处一组表的所有数据和元数据。
4)表空间方式:用于提取一个表空间中所有的数据和元数据,另外还提取依赖于指定表空间列表中所有对象的任何依赖对象。
转储文件:由数据泵到处程序所创建的文件成为转储文件,在单个数据泵导出作业期间所有的转储文件称为转储文件集。
2、基于命令行导出
语法:
c:\expdb system/password directory=pbdir dumpfile=pb.dmp full=y tables=table_list tablespaces=tablesapce_list schemas=schema_list remap_schema=user1:user2 nologfile=y sqlfile=pb.sql
system/passwrod:用户名和密码
directory:数据库目录对象
dumpfile:指定转储文件
full=y:表示实施的全部导入
tables=table_list:表示导入表的列表
schemas=schema_list:表示导入的用户模式
tablespaces=tablesapce_list:表示导入的表空间
remap_schema=user1:user2:表示从user1导入到user2中
nologfile=y:表示不进行日志操作
sqlfile:表示将元数据(DDL语句)写入到指定文件中。
注意:如果需要导出完全数据库,必须具备exp_full_database权限。
1)数据库方式:
注意:如果需要导出完全数据库,必须具备exp_full_database权限。
expdp scott/scott@accp directory=dump_dir dumpfile=full.dmp full=y
2)用户模式方式:
expdp scott/scott@accp directory=dump_dir dumpfile=scottschema.dmp schemas=scott
3)表导出方式:
expdp scott/scott@accp directory=dump_dir dumpfile=tables.dmp tables=emp,dept,bonus,salgrade content=data_only
说明:
content=data_only:data_only表示只导出表中的数据,不导出元数据;metadata_only:则表示只导出元数据而不导出表中的数据。如果不写,则两者全部导出。
4)表空间导出方式:
expdp scott/scott@accp directory=dump_dir dumpfile=tablespace.dmp tablespaces=users
3、DBMS_DATAPUMP进行数据泵导出
使用这种方式比直接使用命令方式要麻烦一些,但是却从数据库作业调度中安排数据泵导出作业的运行日程提供了方便,为数据泵导出提供了更好的功能度和控制度。
declare
--创建数据泵工作句柄
h1 NUMBER;
begin
--建立一个用户定义的数据泵做schema的方案备份。
h1 := DBMS_DATAPUMP.open(operation => 'export',job_mode => 'schema');
--定义存储文件
DBMS_DATAPUMp.add_file(handle => h1,filename => 'es_shop.dmp');
--定义过滤条件
DBMS_DATAPUMP.metadata_filter(handle => h1,name => 'schema_expr',value => 'in''SHOP_USER''');
--启动数据泵会话
DBMS_DATAPUMP.start_job(handle => h1);
--断开数据泵会话
DBMS_DATAPUMP.detach(handle => h1);
end; --默认保存路径:C:\Oracle11g\admin\orcl\dpdump
五、导入
(一)数据泵导入模式
1、导出方式
1)全部导入模式:一个导出文件集的全部内容被装入,该导出文件集不一定是全数据库方式进行导出的。
2)用户模式:指定文件集中的一个用户列表的全部内容被导入。
3、表模式:指定表和相依对象从导出文件中得到导入。
4、表空间模式:指定文件集中属于表空间列表内的所有内容都被导入。
2、使用命令行导入
语法:
c:\impdp system/password directory=pbdir dumpfile=pb.dmp full=y tables=table_list tablespaces=tablesapce_list schemas=schema_list remap_schema=user1:user2 nologfile=y sqlfile=pb.sql
system/passwrod:用户名和密码
directory:数据库目录对象
dumpfile:指定转储文件
full=y:表示实施的全部导入
tables=table_list:表示导入表的列表
schemas=schema_list:表示导入的用户模式
tablespaces=tablesapce_list:表示导入的表空间
remap_schema=user1:user2:表示从user1导入到user2中
nologfile=y:表示不进行日志操作
sqlfile:表示将元数据(DDL语句)写入到指定文件中。
例:
1)导入整个数据库:
impdp scott/scott@accp directory=dump_dir dumpfile=FULL.DMP full=y
2)导入表空间:
impdp scott/scott@accp directory=dump_dir dumpfile=tablespace.DMP tablespaces=mytest
3)导入scott用户下的所有表:
impdp scott/scott@accp directory=dump_dir dumpfile=TABLES.DMP tables=emp,dept,bonus,salgrade
4)将导出的scott用户下的dept和emp表导入到mytest用户下
impdp scott/scott@accp directory=dump_dir dumpfile=SCHEMA.DMP tables=dept,emp remap_schema=scott:mytest
3、DBMS_DATAPUMP进行数据泵导入
declare
--创建数据泵句柄
h1 NUMBER;
begin
--建立一个用户定义的数据泵通过数据泵连接orcllib进行访问。
h1 := DBMS_DATAPUMP.open(operation => 'IMPORT',job_mode => 'schema',remote_link => 'orcllib');
--把shop_dev_data对象模式导入到shop_back对象模式中。
DBMS_DATAPUMP.metadata_remap(handle => h1,name => 'REMAP_SCHEMA',old_value => 'SHOP_DEV_DATA',value => 'SHOP_BACK');
--将日志写入shop.log文件中
DBMS_DATAPUMP.add_file(handle => h1,filename => 'shop.log',filetype => DBMS_DATAPUMP.KU$_FILE_TYPE_LOG_FILE);
--启动数据泵
DBMS_DATAPUMP.start_job(handle => h1);
--断开数据泵连接
DBMS_DATAPUMP.detach(handle => h1);
end;
Oracle基础 数据库备份和恢复的更多相关文章
- Sql Server数据库备份和恢复:原理篇
本文与您探讨为什么Sql Server有完整备份.差异备份和事务日志备份三种备份方式,以及为什么数据库又有简单模式.完整模式和大容量日志模式这三种恢复模式.本文内容适用于2005以上所有版本的Sql ...
- 使用exp&imp工具进行数据库备份及恢复
使用exp&imp工具进行数据库备份及恢复1.exp/imp使用方法介绍exp/imp为一种数据库备份恢复工具,也可以作为不同数据库之间传递数据的工具,两个数据库所在的操作系统可以不同.exp ...
- [原创]Oracle 12c的备份和恢复策略
Oracle 12c的备份和恢复策略(RMAN备份[开启归档/控制文件/数据文件/归档日志]): 备份策略: * 每半年做一个数据库的全备份(包括所有的数据和只读表空间) * 每周做一次零级备份 * ...
- Oracle简单的备份和恢复-导出和导入(1)
ylbtech-Oracle:Oracle简单的备份和恢复-导出和导入(1) Oracle简单的备份和恢复-导出和导入 1. 用户导出自己的表(emp,dept)返回顶部 1.1, 我们启动Oracl ...
- Oracle简单的备份和恢复-导出和导入(2)
ylbtech-Oracle:Oracle简单的备份和恢复-导出和导入(2) 简单的备份和恢复-导出和导入(2) 1. 用户导入导出文件中的一张表(emp)返回顶部 0.1, 我们在sql plus中 ...
- Oracle简单的备份和恢复-导入和导出-目录
ylbtech-Oracle:Oracle简单的备份和恢复-导入和导出-目录 Oracle安全运行离不开良好的备份和恢复机制,因为我们不是DBA.所以我们也就不过多的讲解DBA的备份和恢复.作为程序员 ...
- MongoDB学习总结(六) —— 数据库备份和恢复
我们都知道数据库数据经常备份是多么的重要,MongoDB作为一个数据库系统,自然提供了完善,丰富而且好用的备份与恢复机制. 以下介绍三种数据库备份和恢复的方式 > 数据目录直接拷贝 数据库目录直 ...
- asp.net针对SQLSERVER数据库备份和恢复的一揽子问题解决
一.备份 先备份到服务端,用gridview显示出来,点击可以下载到本地 二.恢复 这是很麻烦的事情,本人查阅不少资料,耗费不少时间才搞定. 直接恢复数据库时不行的,会提示数据库正在使用,恢复失败等信 ...
- 小型网站MYSQL问题二:Percona Xtrabackup实现数据库备份和恢复
1.安装软件仓库(不要问我为什么不用源码安装,好吧,其实我懒.) 1 2 3 4 5 6 7 8 wget https://www.percona.com/downloads/percona-rele ...
随机推荐
- 在ASP.NET MVC中验证checkbox 必须选中 (Validation of required checkbox in Asp.Net MVC)
转载自 http://blog.degree.no/2012/03/validation-of-required-checkbox-in-asp-net-mvc/ Why would you want ...
- [转]Torch是什么?
Torch是一个广泛支持机器学习算法的科学计算框架.易于使用且高效,主要得益于一个简单的和快速的脚本语言LuaJIT,和底层的C / CUDA实现:Torch | Github 核心特征的总结:1. ...
- django admin site配置(二)
1. ModelAdmin.inlines 将有外键的子类包含进视图 ,实例: class Author(models.Model): name = models.CharField(max_leng ...
- URAL 2068 Game of Nuts (博弈)
题意:给定 n 堆石子,每次一个人把它们分成三堆都是奇数的,谁先不能分,谁输. 析:因为每堆都是奇数,那么最后肯定都是要分成1的,那么就把不是1的全加和,然后判断奇偶就OK了. 代码如下: #prag ...
- C#上位机读数据库
string connectionString = string.Format("server=(local);uid=sa;pwd=1234567890;database=msp430&q ...
- (剑指Offer)面试题25:二叉树中和为某一值的路径
题目: 输入一颗二叉树和一个整数,打印出二叉树中结点值的和为输入整数的所有路径.路径定义为从树的根结点开始往下一直到叶结点所经过的结点形成一条路径. 二叉树结点的定义: struct TreeNode ...
- 如何选择PDA的操作系统? Android OR WINCE?
PDA(Personal Digital Assistant),又称为掌上电脑,可以帮助我们完成在移动中工作,学习,娱乐等.按使用来分类,分为工业级PDA和消费品PDA.当我们需要购买PDA的时候, ...
- thinkphp 3+ 观后详解 (5)
static public function dispatch() { $varPath = C('VAR_PATHINFO'); $varAddon = C('VAR_ADDON'); $varMo ...
- PostgreSQL中的AnyArray例子
http://www.joeconway.com/presentations/function_basics.pdf CREATE FUNCTION myappend(anyarray, anyele ...
- 哈希表(Hash)的应用
$hs=@() #定义数组 $hs=@{} #定义Hash表,使用哈希表的键可以直接访问对应的值,如 $hs["王五"] 或者 $hs.王五 的值为 75 $hs=@''@ #定义 ...