expdp/impdp是一个服务端工具,一般建议直接登录到oracle服务器上执行.执行导出和导入的文件必须存放在oracle服务器上面

和exp和imp不同的是,在导出和导入的时候需要提前在oracle中创建一个directory,此目录指向一个操作系统的目录,用来存放导出和导入的文件(oracle用户需要对此文件具有读写权限)

注意,impdp和imp导入的dmp文件不是通用的,exp导出的dmp文件只能用imp进行导入,expdp导出的文件只能用impdp导入,两者不能混用

下面是具体的实例:

1.expdp导出


root登录到需要导出的oracle服务器
##这里创建一个操作系统目录,对应的目录oracle用户需要有读写权限,空间能够存放下导出的文件,这里我们指定/home/oracle/dmp,其它项目根据实际情况修改
mkdir -p /home/oracle/dmp
chown -R oracle:oinstall /home/oracle/dmp

如果是windows系统,则不需要考虑权限问题,直接创建或者指定一个磁盘目录即可

##创建directory

su - oracle
#如果一个服务器上面有多个实例,这里要手工指定一下ORACLE_SID.如果只有一个则不需要指定
export ORACLE_SID=dbserver1
sqlplus / as sysdba 
SQL>drop directory expdir;
SQL>create directory expdir as '/home/oracle/dmp';     --这里的目录和上面创建的目录保持一致

(如果是windows系统,打开cmd执行上面的sqlplus命令即可)


##导出dmp文件,全库导出
expdp \'/ as sysdba\' directory=expdir dumpfile=his20241223.dmp full=y

如果是windows系统上面的\转义不需要,直接expdp '/ as sysdba' 

这里指定了full=y为全库导出,还可以指定schemas或者tables导出指定的schema和表

还有一些其它的参数可以使用expdp help=y来查看


2.impdp导入


#如果是新的导入需要提前先创建好表空间

(impdp是可以导入表空间的,但是必须路径和导出的一致或者配置表空间路径映射,比较麻烦,所以建议提前在要导入的数据库创建好所有需要的表空间)
root登录到需要导入的oracle服务器
##这里创建一个操作系统目录,对应的目录oracle用户需要有读写权限,空间能够存放下导出的文件,这里我们指定/u01/dmp,其它项目根据实际情况修改
mkdir -p /u01/dmp
chown -R oracle:oinstall /u01/dmp
传输dmp导出文件到指定的/u01/dmp下,保证oracle用户对文件可以读写
scp oracle@192.192.2.101:/home/oracle/dmp/his20241223.dmp /u01/dmp

##创建directory
su - oracle

#如果有多个实例需要手工指定一下实例名,如果只有一个则不需要指定
export ORACLE_SID=dbserver
sqlplus / as sysdba
SQL>drop directory expdir;
SQL>create directory expdir as '/u01/dmp';   ----这里的目录和上面dmp存放的目录保持一致

##导入dmp文件
impdp \'/ as sysdba\' directory=expdir dumpfile=his20241223.dmp full=y table_exists_action=replace
#replace表示如果表已经存在会先把表删除再创建,如果不指定table_exists_action则默认会跳过已经存在的表

特别的,如果是采用的是19c CDB架构,需要通过tnsnames里面的服务命名连接到指定的PDB进行导出和导入,还可以并发导出导入等,详细可以使用help=y来查看帮助


 

Logo

魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。

更多推荐