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服务器上的目标数据库中了,迁移成功~