一、问题

由于工作需要,需要把业务库的数据库从oracle签到mysql,免费开源

二、解决办法

2.1:ETL单个对象进行转移(最笨的办法,所以抛弃掉了)

2.2:使用Navicat Premium工具

官网地址:https://www.navicat.com.cn/download,提供14天的试用权限(如下图所示)

安装运行之后,我们开始进行数据迁移吧

a:创建源和目标的连接,比如从oracle到mysql我就首先需要创建一个mysql和oracle的连接

创建MySQL连接是傻瓜式的,我这里不过多的去讲

主要说一下navicat创建Oracle连接,官方文档如下

Navicat 支持两种 Oracle 服务器连接:在 Basic 模式中,Navicat 通过 Oracle Call Interface (OCI) 连接到 Oracle。
OCI 是一个应用程序界面,让程序开发人员使用第三代语言原有进程或函数呼叫来访问 Oracle 数据库及控制全部 SQL
语句运行的阶段。OCI 是一个标准数据库访问的库和动态链接库形式检索函数。
在 TNS 模式中,Navicat 使用在 tnsnames.ora 文件中的别名项目通过 Oracle Call Interface (OCI) 连接到 Oracle
服务器。OCI 是一个应用程序界面,让程序开发人员使用第三代语言原有进程或函数呼叫来访问 Oracle 数据库及控制
全部 SQL 语句运行的阶段。OCI 是一个标准数据库访问的库和动态链接库形式检索函数。

大概就是需要在navicat的选项中指定oci.dll文件的位置,如下图

但是我按照操作安装了oracle client之后指定client中的oci.dll文件的路径一直不行,还是报错,oracle连接一直创建不成功,接下来给出终极

解决方法:

把Oracle安装目录D:\app\Administrator\product\11.2.0\dbhome_1\BIN(根据你的实际安装目录)下的oci.dll文件替换Navicat安装目录D:\software\Navicatfor Oracle\instantclient_10_2(根据你的实际安装目录)下的oci.dll就可以了

确实解决了问题

b:开始迁移数据库

如下图所示,在native中选择工具-数据传输可以看到如下界面,我们定义好源和目标,选择好迁移的对象

遗憾的地方是:Oracle到mysql只能迁移表,视图过程什么的可能是因为语法不一样而被禁用了,或者是因为我这里是使用版的问题,这就不知道了

点击开始迁移,我们可以看到迁移日志,如下图所示

不幸的是,中途却报错了

错误1:[Err] [Dtf] 2006 - MySQL server has gone away With statement: INSERT INTO `T_XX_MESSAGE`

这个错误是因为要插入的字段中含有BLOB、CLOB的大文本字段,MySQL处理能力有限

解决办法:

修改MySQL的my.ini文件(windows),linux为my.cnf,如window解压版的mysql没有my.ini只有my-default.ini

那就复制一个my-default.ini重命名为my.ini在后面加上

max_allowed_packet=16M

结果如下图所示

修改保存后重启mysql服务  net   stop mysql   net start mysql

错误2:

[Msg] [Dtf] Create index: `IDX_MEETING_FILENAME`
[Err] [Dtf] 1170 - BLOB/TEXT column 'FILE_NAME' used in key specification without a key length

解决办法:

原来Mysql数据库对于BLOB/TEXT这样类型的数据结构只能索引前N个字符。所以这样的数据类型不能作为主键,也不能是UNIQUE的。所以要换成VARCH,但是VARCHAR类型的大小也不能大于255,当VARCHAR类型的字段大小如果大于255的时候也会转换成小的TEXT来处理。所以也同样有问题。

作为索引的字符不能太长,修改的短一点吧

继续处理可以发现处理OK,如下图所示

数据库迁移工具Navicat Premium之OracleToMysql的更多相关文章

  1. 软件推荐----数据库数据处理Navicat Premium

    一般情况下,企业对数据库的管控很严,通常管控分成以下: 对整台服务器管理权限,如:操作系统Administrator+SA 对单个数据库(Oracle的表空间)完全权限,如:SQL DB_Owner ...

  2. 数据库工具——Navicat Premium使用技巧

    Navicat Premium 常用功能讲解 1.快捷键 1.1. F8 快速回到当前对象列表  1.2. Ctrl + q 打开查询界面  1.3. Ctrl + d 快速修改当前的表结构  1.4 ...

  3. mysql数据库在Navicat Premium连接的时候出现1862错误

    navicat连接打开时报1862的错误, 很就没有连接mysql看看了,今天连接的时候发现本机的mysql链接不上了,在cmd中执行动作的时候也会叫你去set password,做设置密码的动作时会 ...

  4. 用Navicat Premium 操作MySQL数据库

    1. 用Navicat来查看MySQL数据库        打开Navicat Premium–>[连接]–>[MySQL]–>[连接名:新建数据库的名字,此处为“本地”]:[主机: ...

  5. 通过Navicat Premium迁移Oracle到EDB迁移实战

    1.1 DB migration analysis   在从Oracle向EDB迁移数据之前,须要做非常多准备工作.比方须要分析源数据库数据量大小.数据是否稳定.异构数据库兼容.编码方式.业务逻辑(存 ...

  6. Navicat Premium 12.1.16.0安装与激活

    声明:本文所提供的所有软件均来自于互联网,仅供个人研究和学习使用,请勿用于商业用途,下载后请于24小时内删除,请支持正版! 本文介绍Navicat Premium 12的安装.激活与基本使用.已于20 ...

  7. Navicat Premium 12.1.12.0安装与激活

    转载自:Navicat Premium 12.1.12.0安装与激活 作者:丿记忆灬永殇丨 链接:https://www.jianshu.com/p/5f693b4c9468 navicat12112 ...

  8. Navicat Premium 12.1.11.0安装与激活

    本文介绍Navicat Premium 12.1.11.0的安装.激活与基本使用. 博主所提供的激活文件理论支持Navicat Premium 12.0.x系列和Navicat Premium 12. ...

  9. 我超级推荐的Navicat Premium 12的下载,破解方法

    今天给大家推荐一款炒鸡好用的数据库管理工具,使用它,可以很方便的连接各种主流数据库软件----Navicat Premium 12 但是,它是要钱的,不过我们可以使用破解机来破解它,步骤稍有些复杂,简 ...

随机推荐

  1. MikroTik RouterOS U盘安装工具netinstall的使用

    注意: 1.此工具我没测试成功,比如把一个U盘用这个工具制作好之后,实质上插入电脑启动会有卡死现象,不太稳定. 2.其实官方提供的教程很大一部分是这样的意思,比如把外接硬盘以USB或者SATA的形式插 ...

  2. MSDN WinUSB Example

    The WinUSB user-mode library uses device interface classes to communicate with the kernel-mode USB s ...

  3. 如何自定义 maven中的archetype

    1.首先使用eclipse创建一个新的maven project,然后把配置好的一些公用的东西放到相应的目录下面 比如说会将一些常用的java代码存放到src/main/java目录下面: 会将一些通 ...

  4. 在Visual Studio中使用活动图描述业务流程

    当希望描述某个流程的时候,用活动图表示. 在项目中添加一个名称为"Shopping"的文件夹. 把"Orders Model"这个UML类图拖放到Shoppin ...

  5. 使用Visual Studio 2012远程调试Windows Azure网站

    登录Windows Azure门户,点击"所有项目"中的网站名称. 点击"配置". 在"远程调试"选项中选择"打开",在 ...

  6. indy10的idhttpServer应答字符串

    indy10的idhttpServer应答字符串 先看应答字符串的代码: procedure TIdIOHandler.Write(const AOut: string; AByteEncoding: ...

  7. mormot事务控制

    mormot事务控制 mormot对所有的数据库类型事务都是一样处理方法gProps.SharedTransaction(1, transBegin);try gProps.SharedTransac ...

  8. How To Create A Local Repository For SUSE Linux

    原文地址:http://candon123.blog.51cto.com/704299/1009294/ As you know,you can use the yum command to inst ...

  9. Matlab Codes and Datasets for Feature Learning

    Matlab Codes and Datasets for Feature Learning 浙江大学CAiDeng提供的Matlab特征学习Code.

  10. SharePoint 2016 站点注册工作流服务报错

    前言 安装完SharePoint 2016工作流环境,本来以为万事大吉了,结果给站点注册的时候报错了.搜了很多文章,发现后面要加上-Force参数. 错误截图 使用的为站点注册工作流服务的PowerS ...