Oracle 数据泵 导入导出 最简说明

数据泵可以对含有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;

然后重启数据库。

相关推荐
海市公约2 小时前
MySQL更新语句执行全流程:从Buffer Pool修改到二阶段提交
数据库·mysql·binlog·innodb·undo log·二阶段提交·update执行原理
颂love3 小时前
MySQL的执行流程
android·数据库·mysql
程序leo源3 小时前
Qt窗口详解
开发语言·数据库·c++·qt·青少年编程·c#
这个DBA有点耶3 小时前
COUNT进阶:超大表的近似计数与HyperLogLog
数据库·sql·程序人生·学习方法·dba·改行学it
武子康3 小时前
调查研究-138 全球机器人产业深度调研报告【01 篇】:市场规模、竞争格局与商业化成熟 2026
服务器·数据库·ai·chatgpt·机器人·具身智能
zhojiew4 小时前
在本地PostgreSQL使用pgvector构建生成式 AI 应用的实践
数据库·人工智能·postgresql
Yushan Bai4 小时前
EXADATA X5数据库一体机节点login: failure forking: Cannot allocate memory问题处理
数据库·oracle·vr
KaMeidebaby4 小时前
卡梅德生物技术快报|噬菌体肽库展示技术构建 Mhp168‑Hsp70 定向随机肽库:流程、质控与数据结果
前端·数据库·其他·百度·新浪微博
SelectDB5 小时前
Agent 时代,为什么传统的可观测方案不适用了?
大数据·数据库·数据分析
snowfoootball5 小时前
解决低版本navicat连接PostgreSQl的不兼容报错问题
数据库·postgresql