摘要:前几天师兄交了一个任务,要把一台主机上的数据拷贝到另一台主机。在社区里提问,在众多网友的帮助下,任务得以顺利完成。现将整个思路整理、备案,也为以后遇到同类问题的朋友提供参考。
感谢 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