Oracle中数据迁移的工具

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Oracle中数据迁移的工具相关的知识,希望对你有一定的参考价值。

目前的一个项目中,数据量庞大,大约为九百万左右的数据,而且单条数据量也不小,大约一万条数据,使用100MB的内存,现在需要从这台服务器主机上取数据,但是不能使用数据导出功能(同时不能物理接触到这台服务器主机),现有的办法只有从数据库中读取这张表,然后插入到另外一台服务器主机的的数据库表中,现在请问有那中数据库数据迁徙工具可以达到只迁徙一张表的数据到另外一个数据库的同结构数据.

SQL*Plus Copy命令
问题描述
怎样在SQL*Plus中实现不同的表之间的数据复制,不论是本地的还是远程的?
问题分析
在SQL*Plus中的copy命令,可以完成远程数据库、本地数据库或Oracle数据库与非Oracle数据库之间的数据复制。其性能与导入/导出相同。
copy的基本命令格式:

copy from source_database |to destination_databaseappend|create|insert|replacedestination_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表中。例如:

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
参考技术A 用SQL Server中的DTS工具:
只要在DTS中设定好源数据库,与目的数据库就可以了 不过需要ORACLE 客户端的支持。。。

用Oracle的工具:Oracle migration workbench

以上两种方法都是只能导出表定义和数据的。。。触发器,约束,权限等等都是不能转移的。。

方法很简单的 可视化的。自己摸索一下就行了。。。

请问如何将oracle数据库中的数据迁移到mysql数据库中? 谢谢

建议使用工具来做,直接手工命令相当的麻烦的。
1、
建议使用:Toad for Oracle 10、PLSQL Developer等Oracle工具操作。
把Oracle数据库中的数据转为文本或Excel或保存为sql插入语句,再插入Mysql中,这样就不存在接口字符集差异问题。
2、
也可以使用管道方式直接导入,使用PowerBuilder工具导入。

直接dmp是不现实的!追问

朋友,我安装的是oracle817哈,你说的方法用不上

追答

与Oracle什么版本没有关系。
从来没有听说工具不支持低版本的限制!

参考技术A 方法很多,主要看数据量大小而定。
如果超过30G,那就用专业的ETL软件进行数据备份,例如(微软的SSIS,IBM的Datastage等);
如果10G以下,既可以用上述的软件,也可以简单把数据导出成txt文本或SQL语句,然后在用SQL语句导入到MySQL中。
参考技术B 1.把数据导出到文本中,根据格式分割来入库。
2.把数据导出到Sql文件中,用工具把数据类型更改。再入库。
建议使用工具按照一定格式导出,然后再按照一定格式入库。
参考技术C 安装sqlplus dev 工具里有一导出,可以直接连接ODBC的mysql数据库 参考技术D 用plsql导出所有表的数据,然后刷进去就行了

以上是关于Oracle中数据迁移的工具的主要内容,如果未能解决你的问题,请参考以下文章

如何将ORACLE的数据迁移到MYSQL

怎么将数据库从Oracle迁移到SQL Server,或从Oracle迁移到MySQL

oracle历史数据迁移

oracle数据迁移到mysql中去,数据类型不一致

Oracle数据迁移至MySQL

解决oracle两个的数据库之间数据迁移方法