Oracle数据备份
提示:使用的是数据泵进行操作
一、数据泵是什么?
几乎所有DBA都熟悉oracle的导出和导入实用程序,它们将数据装载进或卸载出数据库,在oracle database 10g和11g中,你必须使用更通用更强大的数据泵导出和导入(Data Pump Export and Import)实用程序导出和导入数据。
二、使用步骤
步骤如下(示例):
1:使用管理员用户登陆 sys as sysdba
2 : 查看现有的逻辑目录 select * from dba_directories;
3:创建逻辑目录 create directory data_back_all as ‘E:/databack/backall’;
4:对逻辑目录的使用授权 grant read,write on directory data_back_all to 用户名;
5:导出数据 : $ expdp 用户名/密码@orcl dumpfile=backalldata.dmp directory=data_back_all full=y logfile=expdp.log;
($符号不能少)
6:导入数: $ impdp 用户名/密码 table_exists_action=append directory=data_back_all dumpfile=backalldata.dmp
注意 table_exists_action配置:
skip 是如果已存在表,则跳过并处理下一个对象,创建表并命名
append 是为表增加数据;
truncate 是截断表,然后为其增加新数据;
replace 是删除已存在表,重新建表并追加数据;
总结
实践总结:
数据泵导出的速度没有导入的速度快,同时在导出的时候可以根据很多条件导出,包括导出某个表,某个表空间,根据查询条件导出,下面给出一些语句:
1:按表空间
$ expdp 用户名/密码@orcl dumpfile=tsoper.dmp tablespaces=TS_OPER logfile=日志.log directory=data_back_all
2:某个表的查询条件
$ expdp 用户名/密码@orcl directory=data_back_all dumpfile=数据文件.dmp logfile=日志.log tables=表名 query=表名:" WHERE 条件";
实例:
$ expdp 用户名/密码@orcl directory=data_back_all dumpfile=edoc_file_object_relation_other.dmp logfile=edoc_file_object_relation_other.log tables=edoc_file_object_relation query=edoc_file_object_relation:" WHERE OBJ_TYPE!=‘com.haiyisoft.entity.gps.GnssPhotoInfo’ or Obj_type is null";