Oracle基础 数据库备份和恢复

简介: 原文:Oracle基础 数据库备份和恢复一、为什么需要数据备份   造成数据丢失的主要原因:   1、介质故障。   2、用户的错误操作。   3、服务器的彻底崩溃。   4、计算机病毒。   5、不可预料的因素。
原文: 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;

 

目录
相关文章
|
10天前
|
DataWorks Oracle 关系型数据库
DataWorks操作报错合集之尝试从Oracle数据库同步数据到TDSQL的PG版本,并遇到了与RAW字段相关的语法错误,该怎么处理
DataWorks是阿里云提供的一站式大数据开发与治理平台,支持数据集成、数据开发、数据服务、数据质量管理、数据安全管理等全流程数据处理。在使用DataWorks过程中,可能会遇到各种操作报错。以下是一些常见的报错情况及其可能的原因和解决方法。
28 0
|
1天前
|
存储 Oracle 关系型数据库
oracle 数据库 迁移 mysql数据库
将 Oracle 数据库迁移到 MySQL 是一项复杂的任务,因为这两种数据库管理系统具有不同的架构、语法和功能。
10 0
|
17天前
|
存储 Oracle 网络协议
Oracle 11gR2学习之二(创建数据库及OEM管理篇)
Oracle 11gR2学习之二(创建数据库及OEM管理篇)
|
21天前
|
Oracle 网络协议 关系型数据库
异地使用PLSQL远程连接访问Oracle数据库【内网穿透】
异地使用PLSQL远程连接访问Oracle数据库【内网穿透】
|
21天前
|
SQL Oracle 安全
Oracle数据库中的事务和锁
【4月更文挑战第19天】Oracle数据库的事务和锁是确保数据完整性和并发控制的核心机制。事务遵循ACID原则,保证操作的原子性、一致性、隔离性和持久性。通过COMMIT或ROLLBACK来管理事务更改。锁包括共享锁(读)、排他锁(写)、行级锁和表级锁,用于控制并发访问。自动锁机制在DML操作时生效,防止数据冲突。事务和锁共同维护数据库的稳定和安全。
|
21天前
|
存储 Oracle 关系型数据库
Oracle RAC:数据库集群的舞动乐章
【4月更文挑战第19天】Oracle RAC是Oracle提供的高可用性数据库解决方案,允许多个实例共享同一数据库,确保业务连续性和数据完整性。通过集群件和全局缓存服务实现服务器间的协调和通信。RAC提供高可用性,通过故障转移应对故障,同时提升性能,多个实例并行处理请求。作为数据管理员,理解RAC的架构和管理至关重要,以发挥其在数据管理中的最大价值。
|
21天前
|
监控 Oracle 安全
Oracle用户事件触发器:数据库世界的“福尔摩斯”
【4月更文挑战第19天】Oracle用户事件触发器是数据库中的监控机制,类似于“福尔摩斯”,在用户执行特定操作时自动触发。它们关注用户行为而非数据变化,可用于权限检查、安全监控、性能优化等。通过DDL语句创建,需注意逻辑清晰、条件合适及定期更新,以适应数据库变化和业务发展。掌握其使用能有效保障数据安全与稳定。
|
21天前
|
SQL 存储 Oracle
Oracle语句级触发器:数据库的“隐形哨兵”
【4月更文挑战第19天】Oracle语句级触发器是数据库中的自动执行程序,当特定事件(如INSERT、UPDATE、DELETE)发生时,会针对整个SQL语句触发。以新员工入职记录日志为例,创建语句级触发器可自动在操作后向日志表插入信息,减少手动工作并提高性能。虽然无法处理行级详细信息,但在处理大量数据时,相比行级触发器更高效。掌握触发器使用能提升数据管理效率和安全性。
|
21天前
|
Oracle 关系型数据库 数据库
Oracle示例模式Scott:数据库世界的“小导游”
【4月更文挑战第19天】Oracle的Scott模式是数据库学习的向导,提供操作性的环境,包含表(如EMP和DEPT)、视图和索引。通过它,学习者能掌握基本语法和操作,如创建表、插入数据和编写查询。它是通往Oracle数据库世界的起点,帮助新手奠定基础,开启数据库探索之旅。
|
21天前
|
存储 Oracle 关系型数据库
Oracle的模式与模式对象:数据库的“城市规划师”
【4月更文挑战第19天】在Oracle数据库中,模式是用户对象的集合,相当于数据库的城市规划,包含表、视图、索引等模式对象。模式对象是数据存储结构,如表用于存储数据,视图提供不同查看角度,索引加速数据定位。良好的模式与模式对象设计关乎数据效率、安全和稳定性。规划时需考虑业务需求、性能、安全和可扩展性,以构建高效数据库环境,支持企业业务发展。