• Oracle 数据库、表、方案的逻辑备份与恢复


    数据库(表)的逻辑备份与恢复

    逻辑备份是指使用工具export将数据对象的结构和数据导出到文件的过程,逻辑恢复是指当数据库对象被破坏而使用工具import利用备份的文件把数据对象导入到数据库的过程,逻辑备份和恢复只能在open的情况下进行。

    一、导出操作

    1、导出

    导出具体分为三种:导出表、导出方案、导出数据库三种方式

    导出使用exp命令来完成的,该命令常用的选项有:

    userid:用于指定执行导出操作的用户名,口令,连接字符串

    tables:用户指定执行导出操作的表

    owner:用于指定执行导出操作的方案

    full=y:用户指定执行导出操作的数据库

    inctype:用于指定执行导出操作的增量类型     也叫增量备份(当第一次备份完之后,第二次备份只会备份新的数据,老的数据不会进行备份)

    rows:用于指定执行导出操作是否要导出表数据

    file:用于指定导出文件名

    2、注意:使用导出操作的口令不能在sqlplus工具中运行,而是在exp.exe程序中执行导出操作,该文件一般位于H:appAdministratorproduct11.2.0dbhome_1BIN,H盘是我的Oracle安装盘,你可以直接点击exe进行操作界面,获取你可以使用cmd,进入界面,下面是使用cmd的导出过程:

    首先进行exp.exe的文件目录,然后执行相关口令.

    3、导出表

    3.1、导出自己的表

    口令:

    exp userid=用户名/密码@数据库实例名 tables=(表名) file=导出表的路径

    首先进行exp.exe的文件目录,然后执行相关口令.

    导出成功!

    3.2、导出其他用户的表

    口令:

    exp userid=用户名/密码@数据库实例名 tables=(方案名.表名) file=导出表的路径

    很多情况system或者sys需要帮助别的用户进行数据的维护,比如表的导出,那这个时候怎样使用sys用户或者system用户登录并导出scott用户的表呢?

     ok,导出成功!!!

    3.3 导出多张表

    口令:

    exp userid=用户名/密码@数据库实例名 tables=(表1名,表2名,表3名) file=导出表的路径

    ok,导出两张表成功d盘下文件存在

    3.4、只导出表的结构(当表中的数据特别大时,只导出表的结构)

    口令:

    exp userid=scott/tiger@orcl tables=(emp) file=d:/test.dmp rows=n

     

    ok,导出成功

    3.5、当表的数据量非常大时,使用"直接导出的方式"来处理这种大表,速度比常规的方法要快

    口令:

    exp userid=scott/tiger@orcl tables=(emp) file=d:aaa.dmp direct=y

    导出成功,且速度很快

    4、导出方案

    导出方案是指导出一个方案或者多个方案中的所有对象(表、索引、约束..)和数据,并存放到文件中。

    4.1、导出自己的方案

    口令:

    exp userid=scott/tiger@orcl owner=scott file=d:scott.dmp

    导出成功,导出了大量的东西

    4.2、导出他人的方案

    如果用户需要导出他人的方案,需要sysdba或者是exp_full_database的权限,例如,system用户就可以导出其他除(sys)用户以外所有用户的方案,这个过程和导出表的一致

    口令如下:

    exp userid=system/manager@orcl owner=(scott) file=D:scott.dmp

    导出成功

    4.3、导出多个方案

     口令:

    exp userid=system/manager@orcl owner=(system,scott) file=d:	est.dmp

    5、导出数据库

     导出数据库是指使用export工具导出数据库中的所有对象及数据,要求用户必须具有sysdba或是exp_full_database的权限

    口令:

    exp userid=system/manager@orcl full=y inctype=complete file=orcl.dmp

     二、导入操作

    导入就是使用工具import将文件中的对象和数据导入到数据库中,导入的文件必须对应导出的文件

    下面是导入关键字imp的常用口令:

    userid:用于指定要执行导入操作的用户名、密码、连接字符串(也就是数据库实例名)

    tables:用于指定要执行导入操作的表

    formuser:用于指定源用户

    touser:用于指定目标用户

    file:用于指定导入文件名

    full=y  用于指定导入整个文件

    inctype:用于指定执行导入操作的增量类型

    rows:用于指定是否要导入表行(数据)

    ignore:如果表存在,则只导入数据

    1、导入表

    口令:

    imp userid=scott/tiger@orcl tables=(emp) file=d:emp.dmp;

    首先使用exp将scott方案下的emp表进行备份,然后删除emp表;

    ok,表删除成功,然后使用imp口令导入emp表

    ok,导入成功,然后

    恢复成功.

    注意:当前哪个方案登录就就将表导入到那个方案下,如果导入的表中存在外键,而当前执行的方案下没有导入表的对应的主键表,那么工具就会报错。

    1.1、导入表到其他用户

    必须使用system或者sys用户或者当前用户具有imp_full_database权限

    口令:

    imp userid=system/manager@orcl tables=(emp) file=d:	est.dmp touser=scott

    作用:使用system用户将emp表导入到scott方案中。

    注意:

    (1)如果scott方案中存在emp表,工具会报错

    (2)如果test.emp不是system方案导出,工具会警告

    1.2、只导入表的结构

    只导入表的结构,不导入数据

    口令:

    imp userid=scott/tiger@orcl tables=(emp) file=d:emp.dmp rows=n

    1.3、只导入数据

    只导入数据,不导入表的结构,前提是表必须存在

    口令:

    imp userid=scott/tiger@orcl tables=(emp) file=d:emp.dmp ignore=y

    2、导入方案

    导入方案是指使用import工具,将文件中的对象和数据导入到一个或者多个方案中去,如果要导入到其他方案中去,则需要有dba或者是imp_full_database的权限

    2.1、导入自身的方案

    口令:

    imp userid=scott/tiger@orcl file=d:scott.dmp

    导入scott方案到orcl数据库下面去

    2.2、导入到其他方案

    要求当前操作用户具有dba或imp_full_database的权限

    口令:

    imp userid=system/manager@orcl file=d:scott.dmp fromuser=system touser=scott

    将d盘下的数据文件导入到scott方案下去,利用system身份

    2.3、导入数据库

     

  • 相关阅读:
    80端口被NT kernel & System 占用pid= 4的解决方法
    黑马程序员:装饰类的作用——增强被装饰类的方法的功能(利用组合实现复用)
    黑马程序员——java基础之文件复制
    10进制转换16进制原理及取得16进制最后一位或倒数第二位
    Django-admin源码流程
    Django-内置Admin
    Django-Form 补充
    有时间的时候可以看看
    编辑器KindEditor的使用
    Git的使用
  • 原文地址:https://www.cnblogs.com/GreenLeaves/p/6640353.html
Copyright © 2020-2023  润新知