壹佰网|ERP100 - 企业信息化知识门户

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 3446|回复: 1

Oracle不同数据库间表的拷贝

[复制链接]
发表于 2007/10/1 15:23:45 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。如果您注册时有任何问题请联系客服QQ: 83569622  。

您需要 登录 才可以下载或查看,没有帐号?注册

x
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<source_select_statement>
其中数据库连接使用如下格式:
username/password@connect_identifier
在数据复制时,复制支持的数据类型为:char、date、long、number、varchar2。原理如图3-9所示。

图3-9 SQL*Plus Copy原理图
SQL*Plus Copy命令可在不同数据库之间,以及同一个数据库内的不同模式的表之间复制数据。
 &#8226;从远程数据库复制数据到本地数据库。
 &#8226;从本地数据库(默认)复制数据到远程数据库。
 &#8226;从一个远程数据库复制数据到另一个远程数据库。
通常,copy命令用于Oracle数据库与非Oracle数据库之间复制数据。如果在Oracle数据库之间复制数据,应该使用create table as 和insert的SQL命令。
&#8226;对目标表的控制方式有4种类型:replace、create、insert和append。
 &#8226;replace子句指定了被创建的表名。如果目标表已存在,则删除并用包含复制数据的表替代。若不存在,则创建目标表。
 &#8226;使用create子句可避免覆盖已存在的表。若目标表已存在,则copy报告一个错误;若不存在,则创建目标表。
 &#8226;insert插入数据到已存在的表。
将查询到的行插入到目标表,如果目标表不存在,copy返回错误。当使用insert时,using子句必须为目标表的每个列选择对应的列。
 &#8226;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/<your_password>@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
发表于 2007/10/21 23:53:04 | 显示全部楼层
顶顶慢慢看。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|Archiver|小黑屋|手机版|壹佰网 ERP100 ( 京ICP备19053597号-2 )

Copyright © 2005-2012 北京海之大网络技术有限责任公司 服务器托管由互联互通
手机:13911575376
网站技术点击发送消息给对方83569622   广告&合作 点击发送消息给对方27675401   点击发送消息给对方634043306   咨询及人才点击发送消息给对方138011526

GMT+8, 2025/11/30 06:57 , Processed in 0.013470 second(s), 14 queries , File On.

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表