数据泵可以对含有CLOB,BLOB等字段的表导出数据,是应用场景最广的一种导入导出方法,我觉得要比SQL Developer好用,不过需要能够登录数据库所在主机的操作系统。
导出
expdp paasapp/Paas1015 datafile=my_data.dmp content={ALL|DATA_ONLY|META_DATA_ONLY} tables=T1,T2,T3
这是导出命令的最简形式,这个命令是针对本机、单实例的情况,这也是使用数据泵的常见场景,不必创建目录和指定导出目录,导出成功后会打印导出文件所在路径,一般在$ORACLE_BASE/admin/platdb/dpdump/,数据泵可以导出表定义、表空间定义、相关索引、授权、触发器、约束的定义等元数据,也可以只导出数据,也可以全部导出。
还有许多其它控制参数,可以参见网上或官网文档。
导入
impdp paasapp/Paas1015 dumpfile=chart_data.dmp content=data_only
这是导入的最简形式,只导入数据,无需创建目录,把chart_data.dmp放到 $ORACLE_BASE/admin/platdb/dpdump/
还有许多其它控制参数,可以参见网上或官网文档。
版本问题
高版本oracle,用数据泵导出的文件,在低版本oracle中导入,会有版本错误,方法是在导出时指定低版本oracle的版本号,例如:
expdp paasapp/Paas1015 datafile=my_data.dmp content={ALL|DATA_ONLY|META_DATA_ONLY} tables=T1,T2,T3 version=11.2
也可以修改导入数据库的compatible参数(如果其compatible参数比实际oracle的版本低的话,我就是这种情况):
ALTER SYSTEM SET COMPATIBLE = '19.3.0' SCOPE=SPFILE;
然后重启数据库。