oracle从远程数据库建立新表,Oracle远程复制表到本地

问题2 SQL*Plus Copy命令

问题描述

怎样在SQL*Plus中实现不同的表之间的数据复制,不论是本地的还是远程的?

问题分析

在SQL*Plus中的copy命令,可以完成远程数据库、本地数据库或Oracle数据库与非Oracle数据库之间的数据复制。其性能与导入/导出相同。

copy的基本命令格式:

copy {from source_database |to destination_database}{append|create|insert|replace}destination_table[(column,column,column,...)]using

其中数据库连接使用如下格式:

username/password\]@connect_identifier

在数据复制时,复制支持的数据类型为:char、date、long、number、varchar2。原理如图3-9所示。

图3-9 SQL*Plus Copy原理图

SQL*Plus Copy命令可在不同数据库之间,以及同一个数据库内的不同模式的表之间复制数据。

 •从远程数据库复制数据到本地数据库。

 •从本地数据库(默认)复制数据到远程数据库。

 •从一个远程数据库复制数据到另一个远程数据库。

通常,copy命令用于Oracle数据库与非Oracle数据库之间复制数据。如果在Oracle数据库之间复制数据,应该使用create table as 和insert的SQL命令。

•对目标表的控制方式有4种类型:replace、create、insert和append。

 •replace子句指定了被创建的表名。如果目标表已存在,则删除并用包含复制数据的表替代。若不存在,则创建目标表。

 •使用create子句可避免覆盖已存在的表。若目标表已存在,则copy报告一个错误;若不存在,则创建目标表。

 •insert插入数据到已存在的表。

将查询到的行插入到目标表,如果目标表不存在,copy返回错误。当使用insert时,using子句必须为目标表的每个列选择对应的列。

 •append是将查询到的行插入到目标表。如果不存在,则创建目标表并插入。

问题解答

首先应注意的是:

1)copy是SQL*Plus命令,不是SQL命令,在语句最后不必加分号;

2)由于多数copy命令比较长,所以,在分行时每行末尾必须有续行符(-),最后一行不加。

具体步骤如下。

步骤1:使用using子句指定一个查询,将其查询结果数据复制到本地数据库的当前模式下employee表中。例如:

copy from hr/hrd@rensh-replace employee-using select last_name,salary-from emp_details_view-where department_id=30

步骤2:使用create从一个远程数据库复制数据到本地数据库。

copy from hr/@bostondb-create empcopy-using select*from hr

步骤3:为其他用户复制数据。

copy from hr/hr@dbora-create job-using select*from renbs.jobs

以用户hr连接到数据库dbora,将renbs模式的jobs表复制到当前本地数据库。

步骤4:在同一个数据库中可将一个模式的表复制到另一个模式中。同样必须指定用户口令和数据库服务名。

copy from hr/password@mydatabase-insert employee_copy2-using select * from employee_copy

步骤5:在同一个远程数据库中复制表,必须是关键字from和to中包含相同用户名和数据库服务名。

copy from hr/password@daliandb-to hr/password@daliandb-insert employee_copy2-using select * from employee_copy

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以按照以下步骤来实现: 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、付费专栏及课程。

余额充值