Oracle中数据迁移的工具

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。 所示。

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表中。例如:

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

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

sql 复制代码
copy from hr/<your_password>@bostondb-create empcopy-using select*from hr 

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

sql 复制代码
copy from hr/hr@dbora-create job-using select*from renbs.jobs   

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

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

sql 复制代码
copy from hr/password@mydatabase-insert employee_copy2-using select * from employee_copy

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

sql 复制代码
copy from hr/password@daliandb-to hr/password@daliandb-insert employee_copy2-using select * from employee_copy
相关推荐
张声录118 分钟前
【ETCD】【实操篇(十五)】etcd集群成员管理:如何高效地添加、删除与更新节点
数据库·etcd
天乐敲代码18 分钟前
Etcd静态分布式集群搭建
数据库·分布式·etcd
chengma_09090920 分钟前
MySQL 数据库连接数查询、配置
数据库·mysql
TDengine (老段)1 小时前
两分钟掌握 TDengine 全部写入方式
大数据·数据库·时序数据库·tdengine·涛思数据
码农君莫笑1 小时前
《信管通低代码信息管理系统开发平台》Windows环境安装说明
服务器·数据库·windows·低代码·c#·bootstrap·.netcore
计算机学长felix1 小时前
基于SpringBoot的“大学生社团活动平台”的设计与实现(源码+数据库+文档+PPT)
数据库·spring boot·后端
木与子不厌1 小时前
微服务自定义过滤器
运维·数据库·微服务
派可数据BI可视化2 小时前
连锁餐饮行业数据可视化分析方案
大数据·数据库·数据仓库·数据分析·商业智能bi
dbcat官方2 小时前
1.微服务灰度发布(方案设计)
java·数据库·分布式·微服务·中间件·架构