Oralce远程数据拷贝

  摘要:前几天师兄交了一个任务,要把一台主机上的数据拷贝到另一台主机。在社区里提问,在众多网友的帮助下,任务得以顺利完成。现将整个思路整理、备案,也为以后遇到同类问题的朋友提供参考。
  感谢
54gj(1751) nojave(我一定要成为程序员)cenlmmx(学海无涯苦作舟) microd(以前是活到老学到老,现在学到老才能活到老) nowait(独行天涯路)qiaozhiwei(乔)guangli_zhang(广丽) 等CSDN好友的帮助!

一、建立连接远程数据库的本地服务
 1、启动Oracle的Net Configuration Assistant
 2、选择“本地网络服务名配置”,next
 3、选择“添加”,next
 4、选择合适的数据库版本,next
 5、填写服务名(如test),next
 6、选择网络通信协议(TCP),next
 7、填写远程主机名(IP地址)及端口号,next
 8、选择是否测试连接
 9、一路狂next到完成。

 10、修改 /oracle/oraHome/network/ADMIN/tnsnames.ora 文件
  TEST =
   (DESCRIPTION =
    (ADDRESS_LIST =
     (ADDRESS = (PROTOCOL = TCP)(HOST =192.168.0.110)(PORT = 1521))
    )
     (CONNECT_DATA =
      (SERVICE_NAME =TEST)
     )
   )
  
   将其中的SERVICE_NAME 项改为要连接远程数据库的服务名,
   如此处数据库服务名为oradb.samlin,则改为SERVICE_NAME =oradb.samlin

二、建立database link
 1、登录本机的Sql×Plus user/password
 2、使用语句
   create database link dblinkName connect to username identified by password using 'service';

  注:dblinkName为要建立的database link名
       username/password为远程数据库的用户名/密码(密码为数字时须用"")
       service为连接远程数据库的本地服务名

三、拷贝数据
 1、拷贝表结构
   使用语句
    create table database.tableName as select * from database.tableB@dblink where 0=1
 
 2、拷贝数据
   使用语句
    insert into database.tableName select * from database.tableB@dblink where xxx=yyy
   如果是全部拷贝使用
    insert into database.tableName select * from database.tableB@dblink

至此数据拷贝完成


注:
   1、用这种CTAS方式须重建约束和索引,若要保留约束和索引可使用exp/imp
   2、若出现监听器无法处理,须将把/oracle/admin/oradb/pfile/init.ora中的参数
     global_names = TRUE 改为 global_names = false

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值