欢迎投稿

今日深度:

数据迁移,数据转移

数据迁移,数据转移


1. 软件支持

1.1下载迁移工具:Navicat_Premium_11.0.10

1.2连接数据库

 1.2.1打开Navicat,点击连接。新建MySQL连接和oracle连接。具体步骤如下图:



(图1)



(图2)

1.2.2连接MySQL数据库:

(图三)

 

2. 在MySQL中创建数据库

2.1打开数据库链接之后,右击,选择新建数据库:



(图四)

2.2填写表信息:


(图五)

3. 迁移表结构


3.1打开Oracle的数据库,右击选择数据传输:


 

(图六)

3.2填写数据传输常规信息:



(图七)

3.3填写数据传输高级信息:


(图八)

3.4迁移完表结构后随机抽取几张表,检查表结构是否正确

4. 修改表结构

4.1迁移完成后,打开Mysql数据库,执行修改表结构的sql脚本(注意,最好不要直接运行sql文件。需要手动删除外键):



(图九)

4.2修改完表结构后随机抽取几张表,检查表结构是否修改正确

5. 修改储存引擎

5.1修改完表结构后,执行修改储存引擎的sql脚本(注意,最好不要直接运行sql文件):

(图十)

5.2修改完储存引擎后随机抽取几张表,检查表的储存引擎是否修改正确

 

6. 导入数据

*lejobdb中以mr开头的表不要导入数据,否则会报错(原因:这张表中有相同的主键)

6.1打开Oracle数据库,右击选择数据传输:如(图六)

6.2填写数据传输常规信息:如(图七)注意:不能导入带有外键的表中的数据

6.3填写数据传输高级信息:注意:导入数据时要使用事务


(图十一)

7. 检查数据

随机抽取所导数据库中的表,检查其中的数据有没有问题。



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

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

以用户h......余下全文>>
 

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

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

以用户h......余下全文>>
 

www.htsjk.Com true http://www.htsjk.com/shujukunews/4410.html NewsArticle 数据迁移,数据转移 1. 软件支持 1.1下载迁移工具:Navicat_Premium_11.0.10 1.2连接数据库 1.2.1打开Navicat,点击连接。新建MySQL连接和oracle连接。具体步骤如下图: (图1) (图2) 1.2.2连接...
评论暂时关闭