千家信息网

oracle上的数据怎么迁移到到mysql

发表于:2025-01-21 作者:千家信息网编辑
千家信息网最后更新 2025年01月21日,这篇文章主要介绍"oracle上的数据怎么迁移到到mysql",在日常操作中,相信很多人在oracle上的数据怎么迁移到到mysql问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对
千家信息网最后更新 2025年01月21日oracle上的数据怎么迁移到到mysql

这篇文章主要介绍"oracle上的数据怎么迁移到到mysql",在日常操作中,相信很多人在oracle上的数据怎么迁移到到mysql问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答"oracle上的数据怎么迁移到到mysql"的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

首先在oracle端和mysql端安装上OGG,安装很简单,然后在oracle源端和目标端配置好mgr(端口需要一致),然后在源端配置上抓取进程,在目标端配置上replicate进程(只运行一次即可),然后在源端使用DEFGEN命令做映射文件,并把文件传到mysql端相应目录下。启动源端的抓取进程即可实现数据库初始化,也就完成了数据迁移。

注意事项和相关报错:

1,oracle到mysql的ogg属于异构的ogg, 需要借助DEFGEN命令生成一个映射文件,也就是两个表的映射关系,并把文件放到目标端相应位置下。否则会报错WARNING OGG-01194 EXTRACT task RINIG1 abended : Could not find definition for INFOSERVICE.T_MEMBER_INFO_SUM

2,在源端配置抓取进程,需要注意的是:初始化数据库过程需要一个的抓取进程,之后保持数据同步也需要一个抓取进程,这两个抓取进程是有区别的,然后目的端也需要两个replicate进程,一个用来初始化数据库,一个用来实时同步数据 。

3,注意oracle字段默认是区分大小写的,但是mysql默认是不区分的。如下:

mysql> select login_id from T_MEMBER_INFO where login_id = 'SHFRONT';

+----------+

| login_id |

+----------+

| shfront |

| SHFRONT |

+----------+

2 rows in set (0.81 sec)

需要这样修改,让mysql对大小写敏感。

mysql> alter table T_MEMBER_INFO modify login_id varchar(100) binary;

mysql> select login_id from T_MEMBER_INFO where login_id = 'SHFRONT';

+----------+

| login_id |

+----------+

| SHFRONT |

+----------+

1 row in set (0.78 sec)

如果mysql的主键是login_id,那么可能会遇到下面这个报错,主键冲突,真正的原因是:mysql字段值默认是不区分大小写

报错:WARNING OGG-01004 Aborted grouped transaction on 'liuwenhe.T_MEMBER_INFO_SUM', Database error 1062 ([SQL error 1062]Duplicate entry 'shandongchaoyue' for key 'PRIMARY'

从oracle转到MySQL的OGG,在使用mysql过程中,会遇到很多不同于oracle的问题,初始化数据的时候总是报主键冲突,但是这些数据都是从同样表结构的oracle数据库中导出来的,当然主键也是一样的。

查看了一下数据文件,发现存在很多数据只是大小写不一样,如'goolen,'GOOLEN','Goolen'这样的数据,

其实MySQL中,字段值默认是不区分大小写的,也就是说插入值'abc'和'ABC'是等价的,

下面展示具体的配置:

源端oracle 抓取进程配置:

[oracle@master2 ggs]$ cd /u01/OGG_linux/ggs

[oracle@master2 ggs]$ ./ggsci

Oracle GoldenGate Command Interpreter for Oracle

Version 11.2.1.0.1 OGGCORE_11.2.1.0.1_PLATFORMS_120423.0230_FBO

Linux, x64, 64bit (optimized), Oracle 11g on Apr 23 2012 08:32:14

Copyright (C) 1995, 2012, Oracle and/or its affiliates. All rights reserved.

1,GGSCI (master2) 1> create subdirs

Creating subdirectories under current directory /u01/OGG_linux/ggs

Parameter files /u01/OGG_linux/ggs/dirprm: already exists

Report files /u01/OGG_linux/ggs/dirrpt: created

Checkpoint files /u01/OGG_linux/ggs/dirchk: created

Process status files /u01/OGG_linux/ggs/dirpcs: created

SQL script files /u01/OGG_linux/ggs/dirsql: created

Database definitions files /u01/OGG_linux/ggs/dirdef: created

Extract data files /u01/OGG_linux/ggs/dirdat: created

Temporary files /u01/OGG_linux/ggs/dirtmp: created

Stdout files /u01/OGG_linux/ggs/dirout: created,

2,登录数据库

GGSCI (master2) 3> dblogin userid ogg,password ogg

Successfully logged into database.

3,添加需要同步的用户到ogg

开启scott用户下所有表的附加日志

GGSCI (WebServer) 3> add trandata infoservice.*

2013-03-08 11:02:33 WARNING OGG-00869 No unique key is defined for table 'BONUS'.

All viable columns will be used to represent the key, but may not guarantee

uniqueness. KEYCOLS may be used to

define the key.

Logging of supplemental redo data enabled

for table SCOTT.BONUS.

Logging of supplemental redo data enabled

for table SCOTT.DEPT.

Logging of supplemental redo data enabled

for table SCOTT.EMP.

2013-03-08 11:02:34 WARNING OGG-00869 No unique key is defined for table

'SALGRADE'. All viable columns will be used to represent the key, but may not

guarantee uniqueness. KEYCOLS may be

used to define the key.

Logging of supplemental redo data enabled

for table SCOTT.SALGRADE.

4,GGSCI (WebServer) 4> info trandata scott.*

Logging of supplemental redo log data is

enabled for table SCOTT.BONUS.

Columns supplementally logged for table

SCOTT.BONUS: ENAME, JOB, SAL, COMM.

Logging of supplemental redo log data is

enabled for table SCOTT.DEPT.

Columns supplementally logged for table

SCOTT.DEPT: DEPTNO.

Logging of supplemental redo log data is

enabled for table SCOTT.EMP.

Columns supplementally logged for table

SCOTT.EMP: EMPNO.

Logging of supplemental redo log data is

enabled for table SCOTT.SALGRADE.

Columns supplementally logged for table

SCOTT.SALGRADE: GRADE, LOSAL, HISAL.

3,GGSCI (master2) 3>edit params mgr

PORT 7839

4,GGSCI (master2) 3> start mgr

5,GGSCI (master2) 3>info mgr

Manager is running (IP port

WebServer.7839).

1.抓取进程

GGSCI (oracle3) 10>add extract ext_1,sourceistable ####sourceistable代表直接从表中读取数据

GGSCI (oracle3) 10> view params ext_1

extract ext_1

setenv (NLS_LANG=AMERICAN_AMERICA.ZHS16GBK)

userid goldengate@cbl , password ogg123456

rmthost 192.168.0.12,mgrport 7839

rmttask replicat,group rinig1

table INFOSERVICE.T_MEMBER_INFO;

2.DEFGEN命令生成的映射文件。

1)创建DEFGEN工具的参数文件;

GGSCI (oracle3) 3> view params defgen

defsfile ./dirdef/source.def, purge

userid ogg@rman_cbl1 , password ogg

TABLE INFOSERVICE.T_PUBLISH_INFO;

TABLE INFOSERVICE.T_PUBLISH_ZBXX;

TABLE INFOSERVICE.T_MEMBER_INFO;

TABLE INFOSERVICE.T_MEMBER_INFO_FUBIAO1;

TABLE INFOSERVICE.T_MEMBER_INFO_SUM;

TABLE INFOSERVICE.T_MEMBER_MY;

TABLE INFOSERVICE.T_MEMBER_MY_INFO;

TABLE INFOSERVICE.T_PUBLISH_INFO_SUM_TONGJI;

TABLE INFOSERVICE.USER_REGIST_LS_FAIL;

TABLE INFOSERVICE.USER_REGIST_LS;

2))运行DEFGEN工具生成数据定义文件

进入GGSCI安装目录下,命令行执行:

[oracle@oracle3 ogg]$./defgen paramfile dirprm/defgen.prm

3)把生成的文件 scp到目标端相应文件下:

[oracle@oracle3 ogg]scp /home/oracle/ogg/dirdef/source.def root@192.168.0.12:/files/ogg/dirdef/source.def

目标端:replicate 配置:

GGSCI (db2) 1> add replicat rinig1,specialrun //specialrun代表只运行一次

注意下面的target liuwenhe.T_MEMBER_INFO

GGSCI (server02) 12> view params rinig1

replicat rinig1

sourcecharset ZHS16GBK

setenv (NLS_LANG=AMERICAN_AMERICA.zhs16gbk)

sourcedefs ./dirdef/source.def

sourcedb infoservice,userid ogg,password ogg

discardfile ./dirrpt/rinig1.dsc,purge

map infoservice.T_MEMBER_INFO, target liuwenhe.T_MEMBER_INFO REPERROR (1403, discard);

最后打开源端的抓取进程即可

GGSCI (oracle3) 3>start ext_1

GGSCI (oracle3) 3> view report ext_1 ###查看输出结果

最后可以看日志:

ogg错误日志

[root@server02 dirdef]# find / -name ggserr.log

[root@server02 dirdef]#tail -f /files/ogg/ggserr.log

总结:

oracle到mysql的ogg需要借助defgen命令生成的映射文件,并把文件传到目标端相应位置下,才能完成数据库初始化,用于初始化的replicate进程,只会运行一次。注意字符集问题,就是源端的抓取进程配置的字符集和目标端replicate配置的字符集必须是一样的,否则可能会导致只导进去一部分数据。

到此,关于"oracle上的数据怎么迁移到到mysql"的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注网站,小编会继续努力为大家带来更多实用的文章!

数据 进程 文件 配置 目标 数据库 命令 生成 大小 学习 运行 两个 字段 字符 字符集 日志 端的 问题 同步 也就是 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 信誉好的浪潮服务器代理商哪里有 软件开发管理qa 远程办公网络安全意识培训 济南学也互联网科技有限公司 数据库中避免死锁 新斗罗大陆服务器表 计算机软件开发绪论 铁血数据库怎么用 ti 多核软件开发技术 浙江飞灵软件开发有限公司 我的世界小蜜蜂服务器怎么刷点卷 大华存储服务器一直报警 统一软件开发过程 实例 软件开发的技术特点 我的世界服务器里的东西被破坏 部队基层网络安全 员工网络安全行为 碧桂园软件开发待遇 德州服务器运维管理系统销售 个人搭建微信小程序服务器 网络安全防范用语 小程序数据库连接文件 网络安全责令改正通知书 框架在软件开发中的作用 数据库flage什么意思 软件开发与计算机应用哪个好 云服务器如何储存数据 浪潮服务器主板电池如何抠出 河北银行微服务架构数据库 大专工业网络技术升本专业
0