oracle不同数据库/数据库用户间的数据同步 数据泵exp/imp sqlldr(sql loader) dblink

参考:
https://blog.csdn.net/shadow_zed/article/details/82661118

说明:本文中只做简单说明,深入研究等后续用到了再补

1、数据泵exp/imp

同步表结构+数据
很多参数没有使用到,具体用法执行命令exp/imp -help查看吧

1、导出

exp user/passwd@ip:port/orcl grants=Y file=C:\desktop\t1202.dmp log=lxtest.log owner=xx rows=n
## file 输出文件的全路径名称
## log exp执行日志打印全路径文件名
## owner 导出哪个用户的表
## rows=n 表示只导出表结构

2、导入 - 需要注意导入数据的用户,要有dba权限

imp user/passwd@ip:port/orclpdb file=C:\desktop\t1202.dmp fromuser=xx touser=user ignore=y log=lxtest.log
## file 导入的dmp文件名称
## fromuser从哪个用户导出的
## touser导入到哪个用户

2、sqlldr(sql loader)

仅同步数据,表结构需要其他方式同步
这个一般是把数据导出成csv等数据类型的文件。然后通过sqlldr命令指定一些操作信息,把数据加载进入数据库。
执行的参数中可能会涉及到的一个主要的文件路径,该文件是执行控制文件(会在控制文件中说明一些信息,比如要将cav中的数据加载到哪张表,csv的哪列对应表中的哪个字段,记录的分隔符,要加载哪个csv文件等),注意有些时候控制信息也会和数据库数据放在同一个文件中。

#sqlldr命令示例
sqlldr dbuser/dbpass@dbservice control=xxx.ctl

3、dblink(database link)

仅同步数据,表结构需要其他方式同步
这个其实也是用insert into xx select xx from xx@dblink;这种形式来进行数据插入。
而且这个我记得有个限制,貌似clob相似类型的大字段,会无法select,也就会导致表中存在大字段时,大字段的数据无法同步。

--简单的创建、删除dblink的命令
-- 创建database link
create public database link dblink_name connect to target_db_user identified by target_db_passwd using 'target_db_server';
-- 删除database link
drop public database link dblink_name;
-- 查询已经存在的dblink
select * from all_db_links;

4、导出表创建+数据insert语句,在新库执行

仅同步数据,表结构需要其他方式同步
大量insert时,尽量关闭 REDO (这个日志具体不太清楚都做了些什么,需要仔细了解下,看看会不会有啥问题),来提高 insert into的性能

--关闭xx表的REDO
alter table XX nologging;
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值