oracle数据库通过dlink实现无落地迁移

oralce数据库迁移有很多种方式,

①:传统方式——exp(导出)和(imp)导入:
②:数据泵方式——expdp导出和(impdp)导入;
③:第三方工具——PL/sql Develpoer;

 

这边我不一一说明了,这边直说如何通过dlink+impdp实现无落地迁移

啥叫无落地迁移?就是不需要导出dmp文件,然后再导入进去,省略了这个步骤,只需要在目标数据库中创建一个tns、dlink、然后通过impdp命令直接导入迁移数据库。

话不多说,直接开搞

1.首先我们分源数据库和目标数据库,首先源数据库中的oracle实例名是wlfdb,表空间是wulinfeitab,用户名是c##wulinfei,

密码是123456789Wuw,然后这边我们需要将源数据库中给迁移到新的数据库中去,

我们这边对应在目标数据库上创建跟源数据库一样的实例,用户名,表空间等等


--创建表空间。这个路径不需要提前创建,执行完了之后自动生成
create tablespace wulinfeitab
datafile '/u01/app/oracle/oradata/wlfdb/wulinfeitab.dbf'
size 500m; 

--创建oracle用户,指定表空间
create user c##wulinfeis identified by "123456789Wuw"  default tablespace wulinfeitab;

--给新建的用户权限
grant create session,resource,connect,exp_full_database,imp_full_database to c##wulinfeis;

--ORA-01950: no privileges on tablespace xxxx   授予用户对该表空间的UNLIMITED配额
ALTER USER c##wulinfeis QUOTA UNLIMITED ON wulinfeitab;

然后我们在源数据库中创建两张表,插入几条数据作为我们迁移是否成功的测试凭证。

在192.168.33.109服务器上的源数据库创建test_a和test_b

 

2.在目标数据库配置tns

TNSWLFDB =
  (DESCRIPTION =
    (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.33.109)(PORT = 1521))
    (CONNECT_DATA =
      (SERVER = DEDICATED)
      (SERVICE_NAME = wlfdb)
    )
  )

2.在目标数据库中创建dlink

--创建dlink
create public database link testscotts connect to c##wulinfeis identified by "123456789Wuw" using 'TNSWLFDB';

成功创建dlink之后,我们有两种方式测试你的tns和dlink是否配置成功

first:输入命令tnsping tns名字

second:查询表的时候,带上@dlink的名字,就可以通过dlink访问到源数据库中的表了。

3.然后执行导入命令

impdp \'/ as sysdba\' network_link=testscotts schemas=c##wulinfeis

 

登录我们刚刚创建的用户,可以看到,刚刚我们在源数据库中创建的两张表已经被我迁移到我们的192.168.33.110服务器上的目标数据库中了,迁移成功~

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值