Oracle导出远程数据库再导入本地数据库-命令方式

因为毕设用的是公司的系统,所以要导出远程数据库再导入本地数据库


本来用PL/SQL工具的导出导入表是十分好用的,但是不知道为什么一直用SQL导出会报错,用ORACLE导出可执行文件没用。。。也算是很倒霉了。。。


不得已之下只好用命令行了。


1、导出dmp文件


exp user/password@192.168.1.40:1521/ETL file=F:\xxx.dmp owner=lyzhjt

因为我们公司的40上有好多项目的数据库,所以要采取owner导出,否则可以采取full = y 导出


2、导入dmp文件

首先在SQLPLUS里以你想要导入的用户登录

imp user/password@192.168.1.40:1521/ETL  full=y file=F:\xxx.dmp


3、我是自己又创建了一个本地的账户的,在授予权限的时候,没有授予导入的权限,所以导致一开始无法导入。


grant create user,drop user,alter user ,create any view ,
      drop any view,exp_full_database,imp_full_database,
      create session to wqq

4、怎么创建表空间-用户-表可以参考我上篇文章(转载)Oracle - 数据库的实例、表空间、用户、表之间关系



可以按照以下步骤来实现: 1. 在远程数据库中创建一个只包含指定schema的数据泵导出文件,可以使用以下命令: ``` expdp <username>/<password> schemas=<schema_name> directory=<directory_name> dumpfile=<dump_file_name>.dmp logfile=<log_file_name>.log ``` 其中,`<username>`和`<password>`是远程数据库的用户名和密码,`<schema_name>`是要导出的schema名称,`<directory_name>`是数据泵导出文件存储的目录名称,`<dump_file_name>`是导出文件的名称,`<log_file_name>`是日志文件的名称。 2. 将导出文件传输到本地系统中。 3. 在本地数据库中创建一个与远程数据库中schema名称相同的用户,并授予该用户创建表的权限。 4. 在本地数据库中创建一个目录对象,用于存储数据泵导入文件,可以使用以下命令: ``` CREATE DIRECTORY <directory_name> AS '<directory_path>'; ``` 其中,`<directory_name>`是目录对象的名称,`<directory_path>`是目录的路径。 5. 在本地数据库中使用以下命令导入数据泵文件: ``` impdp <username>/<password> directory=<directory_name> dumpfile=<dump_file_name>.dmp logfile=<log_file_name>.log remap_schema=<schema_name>:<local_schema_name> ``` 其中,`<username>`和`<password>`是本地数据库的用户名和密码,`<directory_name>`是数据泵导入文件存储的目录名称,`<dump_file_name>`是导出文件的名称,`<log_file_name>`是日志文件的名称,`<schema_name>`是远程数据库中要导入的schema名称,`<local_schema_name>`是本地数据库中要创建的schema名称。 这样就可以将远程数据库中指定的schema导入到本地数据库中了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值