分享更有价值
被信任是一种快乐

Oracle数据泵技术常用操作有哪些

文章页正文上

这篇文章主要介绍“Oracle数据泵技术常用操作有哪些”,在日常操作中,相信很多人在Oracle数据泵技术常用操作有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Oracle数据泵技术常用操作有哪些”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!1. 为什么选择数据泵数据泵是Oracle 10g开始引入的新技术,对现在来说已经不是新技术了,11g都已经结束标准支持期了。技术更新从10g版本开始,数据泵技术跟随新版本进行不断的完善,对新版本的Oracle数据库具有更强的适应性。BUG更少数据泵可以使用直接路径、并行等特性,对大数据量的迁移来说,具有更好的性能,可以减少大量导入导出时间。性能更好exp/imp不能导出空表,而且由于从10g开始停止更新,后面版本引入的新对象都不支持导出,如自定义对象。功能更强1.1. 与exp/imp的主要区别 exp/imp是客户端工具,可以在客户端使用;数据泵是服务端工具,只能在服务端使用。 exp/imp不能导出空表;数据泵可以。 exp/imp跟数据泵导出的文件不能通用。2. 基本概念数据泵的命令行命令是expdp/impdp,是一种数据库之间移动数据的工具。目录(directory)是Oracle的一种对象类型,可以认为是一个指向物理存储路径的指针,用来指定数据泵导出导入文件使用的路径。模式(schema)是一组数据库对象的集合,一般一个用户对应一个schema。3. 基本步骤3.1 创建目录SQL> create directory
dump_dir as ‘/home/oracle/dump’;dump_dir 是目录名称;可以根据实际情况自己定义,不重复免费主机域名可,如果系统中已经存在,可以直接使用;/home/oracle/dump 是操作系统物理路径;必须保证该路径真实存在,并具有足够空间存放备份文件;3.2 授权SQL> grant read,write on directory
dump_dir to
public;dump_dir 是上面创建得目录名称;public 表示这个目录是公开的;也可以针对某个用户授权;3.3 执行导入导出$ expdp
system/dbmanager directory=dump_dir
full=Y dumpfile=full_20190101.dmp logfile=full_expdp_20190101.log$ impdp system/免费主机域名dbmanager directory=dump_dir dumpfile=full_20190101.dmp logfile=full_impdp_20190101.logsystem 是导出命令所用的用户;dbmanager 是system用户的密码;dump_dir 是上面创建得目录名称;full=Y 表示全库导出;dumpfile/logfile 根据实际情况命名即可;该命名需要能够描述备份的内容及时间等基本信息;该命名重复的话会覆盖4. 常用方式4.1 expdp 导出##导出一张表,例:expdp system/dbmanager directory=dump_dir dumpfile=emp_20190101.dmp logfile=emp_expdp_20190101.log tables=scott.emp##导出多张表,例:expdp system/dbmanager directory=dump_dir dumpfile=empdept_20190101.dmp logfile=empdept_expdp_20190101.log tables=(scott.emp,scott.dept)##导出一个用户(导出这个用户的所有对象),例:expdp system/dbmanager directory=dump_dir dumpfile=scott_20190101.dmp logfile=scott_expdp_20190101.log schemas=scott##导出多个用户,例:expdp system/dbmanager directory=dump_dir dumpfile=scotthr_20190101.dmp logfile=scotthr_expdp_20190101.log schemas=(scott,hr)##导出整个数据库(sys的用户数据不会被导出),例:expdp system/dbmanager directory=dump_dir dumpfile=full_20190101.dmp logfile=full_expdp_20190101.log full=y##并行导出,例:expdp system/dbmanager directory=dump_dir dumpfile=scott_20190101_%U.dmp logfile=scott_expdp_20190101.log schemas=scott parallel=8##导出用户元数据(包含表定义、存储过程、函数等等),例:expdp system/dbmanager directory=dump_dir dumpfile=scott_20190101.dmp logfile=scott_expdp_20190101.log schemas=scott content=metadata_only##导出用户存储过程,例:expdp system/dbmanager directory=dump_dir dumpfile=scott_20190101.dmp logfile=scott_expdp_20190101.log schemas=scott include=procedure##导出用户函数和视图,例:expdp system/dbmanager directory=dump_dir dumpfile=scott_20190101.dmp logfile=scott_expdp_20190101.log schemas=scott include=(function,view)##导出一个用户,但不包括索引,例:expdp system/dbmanager directory=dump_dir dumpfile=scott_20190101.dmp logfile=scott_expdp_20190101.log schemas=scott exclude=index4.2 impdp导入##导入dmp文件中的所有数据,例:impdp system/dbmanager directory=dump_dir dumpfile=full_20190101.dmp logfile=full_impdp_20190101.log full=y##导入一张表,例:impdp system/dbmanager directory=dump_dir dumpfile=full_20190101.dmp logfile=full_impdp_20190101.log tables=scott.emp##导入多张表,例:impdp system/dbmanager directory=dump_dir dumpfile=full_20190101.dmp logfile=full_impdp_20190101.log tables=(scott.emp,scott.dept)##导入一个用户,例:impdp system/dbmanager directory=dump_dir dumpfile=full_20190101.dmp logfile=full_impdp_20190101.log schemas=scott##导入多个用户,例:impdp system/dbmanager directory=dump_dir dumpfile=full_20190101.dmp logfile=full_impdp_20190101.log schemas=(scott,hr)##并行导入,例:impdp system/dbmanager directory=dump_dir dumpfile=full_20190101_%U.dmp logfile=full_impdp_20190101.log parallel=5##导入元数据(包含表定义、存储过程、函数等等),例:impdp system/dbmanager directory=dump_dir dumpfile=full_20190101.dmp logfile=full_impdp_20190101.log content=metadata_only##导入存储过程,例:impdp system/dbmanager directory=dump_dir dumpfile=full_20190101.dmp logfile=full_impdp_20190101.log include=procedure##导入函数和视图,例:impdp system/dbmanager directory=dump_dir dumpfile=full_20190101.dmp logfile=full_impdp_20190101.log include=(function,view)##导入数据,但不包括索引,例:impdp system/dbmanager directory=dump_dir dumpfile=full_20190101.dmp logfile=full_impdp_20190101.log exclude=index##重命名表名导入,例:impdp system/dbmanager directory=dump_dir dumpfile=full_20190101.dmp logfile=full_impdp_20190101.log remap_table=scott.emp:emp1##重命名schema名导入,例:impdp system/dbmanager directory=dump_dir dumpfile=full_20190101.dmp logfile=full_impdp_20190101.log remap_schema=scott:tim##重命名表空间名导入,例:impdp system/dbmanager directory=dump_dir dumpfile=full_20190101.dmp logfile=full_impdp_20190101.log remap_tablespace=users:pams##将dmp文件的ddl语句导入到一个文件,不导入数据库,例:impdp system/dbmanager directory=dump_dir dumpfile=full_20190101.dmp logfile=full_impdp_20190101.log sqlfile=import.sql5. 常用参数5.1 expdp参数说明attach=[schema_name.]job_name说明:nodefault。连接到作业,进入交互模式。##导出模式,以下五个参数互斥:full=[ Y |
N ]说明:导出所有数据和元数据。要执行完全导出,需要具有datapump_exp_full_database角色。schemas=schema_name[,…]说明:导出用户。tables=[schema_name.]table_name[:partition_name][,…]说明:导出表。tablespaces=tablespace_name[,…]说明:导出表空间。transport_tablespaces=tablespace_name[,…]说明:导出可移动表空间。##过滤条件,以下三个参数互斥:query=[schema.][table_name:] query_clause说明:按查询条件导出。exclude=object_type[:name_clause][,…]说明:排除特定的对象类型。include=object_type[:name_clause][,…]说明:包括特定的对象类型。##其他参数:directory=directory_object说明:导出路径。dumpfile=file_name[,…]说明:导出的文件名。logfile=file_name说明:导出的日志文件名。content=[
all | data_only | metadata_only]说明:指定要导出的数据。parallel=integer说明:并行度,该值应小于等于dmp文件数量,或可以为’dumpfile=’使用替换变量’%U’。RAC环境中,并行度大于1时,注意目录应该为共享目录。compression=[ all | data_only |
metadata_only | none ]说明:压缩。parfile=[directory_path]file_name说明:指定导出参数文件名称。filesize=integer[b|kb|mb|gb|tb]说明:指定每个dmp文件的最大大小。如果此参数小于将要导出的数据大小,将报错ORA-39095。5.2 impdp参数说明attach=job_name说明:连接到作业,进入交互模式。导入模式,以下五个参数互斥。full=[
Y | N ]说明:导入dmp文件的所有数据和元数据。schemas=schema_name[,…]说明:导入用户。tables=[schema_name.]table_name[:partition_name][,…]说明:导入表。tablespaces=tablespace_name[,…]说明:导入表空间。transport_tablespaces=tablespace_name[,…]说明:导入可移动表空间。过滤条件,以下三个参数互斥:query=[schema.][table_name:] query_clause说明:按查询条件导入。exclude=object_type[:name_clause][,…]说明:排除特定的对象类型。include=object_type[:name_clause][,…]说明:包括特定的对象类型。其他参数:directory=directory_object说明:导入路径。dumpfile=file_name[,…]说明:导入的文件名。logfile=file_name说明:导入的日志文件名。content=[
all | data_only | metadata_only ]说明:指定要导入的数据。parallel=integer说明:并行度,该值应小于等于dmp文件数量,或可以为’dumpfile=’使用替换变量’%U’。parfile=[directory_path]file_name说明:指定导入参数文件名称。REMAP_TABLE=[schema.]old_tablename[.partition]:new_tablename说明:允许导入期间重命名表名。REMAP_SCHEMA=source_schema:target_schema说明:允许导入期间重命名schema名。REMAP_TABLESPACE=source_tablespace:target_tablespace说明:允许导入期间重命名表空间名。SQLFILE=[directory_object:]file_name说明:根据其他参数,将所有的 SQL DDL 写入指定的文件。TABLE_EXISTS_ACTION=[
SKIP |
APPEND | TRUNCATE | REPLACE ]说明:default:skip(if
content=data_only is specified,then the default is
append)6. 注意事项6.1 directory相关SQL语句:##查看目录select * from dba_directories;##创建目录create directory dump_dir as ‘/home/oracle/tmp’;##目录授权grant read,write on directory my_dir to public;6.2 expdp导出1、导数的数据库用户需要拥有对directory_object的读写权限。2、操作系统中需要已经存在directory_object指定的路径。3、oracle用户拥有对directory_object指定路径的读写权限。4、system用户导出用户,会将创建用户和授予系统权限的元数据也导出,普通用户不能导出这些元数据。6.3 impdp导入1、expdp导出的文件不能使用imp导入,只能通过impdp导入数据库。2、导入时遇到已存在的对象,默认会跳过这个对象,继续导入其他对象。3、导入时应确认dmp文件和目标数据库的tablespace、schema是否对应。4、导入dmp文件时,应确定dmp文件导出时的命令,以便顺利导入数据。6.4 交互模式进入交互可以操作导入导出作业。进入交互模式的方法:1、导入导出命令行执行期间按Ctrl + c2、expdp attach=jobname或impdp attach=jobnam查看导入导出日志可以看到jobname,也可以通过查询dba_datapump_jobs找到jobname。6.5 常见报错系统目录未建立,报错:ORA-39002: invalid operationORA-39070: Unable to open the log file.ORA-29283: invalid file operationORA-06512: at “SYS.UTL_FILE”, line 536ORA-29283: invalid file operationimpdp导入exp导出的dmp文件,报错:ORA-39000: bad dump file specificationORA-39143: dump file “/orabak/pams_20190101.dmp” may be an original export dump file如果导出的数据库版本比导入的数据版本高,需要在导出时加上参数version=要导入的数据库版本。否则报错:ORA-39001: invalid argument valueORA-39000: bad dump file specificationORA-31640: unable to open dump file “/orabak/pams_20190101.dmp” for readORA-27037: unable to obtain file status到此,关于“Oracle数据泵技术常用操作有哪些”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注云技术网站,小编会继续努力为大家带来更多实用的文章!

相关推荐: PostgreSQL中grouping_planner函数有什么作用

这篇文章主要介绍“PostgreSQL中grouping_planner函数有什么作用”,在日常操作中,相信很多人在PostgreSQL中grouping_planner函数有什么作用问题上存在疑惑,小编查阅了各免费主机域名式资料,整理出简单好用的操作方法,希…

文章页内容下
赞(0) 打赏
版权声明:本站采用知识共享、学习交流,不允许用于商业用途;文章由发布者自行承担一切责任,与本站无关。
文章页正文下
文章页评论上

云服务器、web空间可免费试用

宝塔面板主机、支持php,mysql等,SSL部署;安全高速企业专供99.999%稳定,另有高防主机、不限制内容等类型,具体可咨询QQ:360163164,Tel同微信:18905205712

主机选购导航云服务器试用

登录

找回密码

注册