• 售前

  • 售后

热门帖子
入门百科

深入ORACLE迁徙到MYSQL的总结分析

[复制链接]
123457441 显示全部楼层 发表于 2021-10-26 13:22:24 |阅读模式 打印 上一主题 下一主题
这两个星期里不停都在忙于一件事儿,就是数据库的迁徙题目。没有做的时候感觉这是一件非常轻松的事儿,但是等到实着实在去做去实现的时候,本身傻眼了。这种纠结啊,

在这里先说下碰到的题目:
1。数据库的表结构题目:数据类型不同必要解决varchar2------varchar、number-----int、date----datetime,建表的sql语句字段默认值、表明怎么解决。

2. oracle中没有所谓的敏感字段,但是mysql表中的敏感字段有很多多少。其时堕落的时候很奇怪不知道是那边错了。原来有个describe的字段是mysql的敏感字段。

这里我也是在网上找了一个现成的工具:oracletomysql,它是只能为我们迁徙表结构。
详细地址:http://www.5stardatabasesoftware.com/cn/

3. oracle的备份sql没法正常的mysql中跑,一些to_date()函数,to_char()让人非常痛楚不知道怎么去代替,缘故原由很简单在oracle的备份文件中有一堆的表明笔墨:
复制代码 代码如下:
prompt PL/SQL Developer import file
prompt Created on 2012-05-30 by chenbh
set feedback off
set define off
prompt Disabling triggers for T_B_AUDITOR...
alter table T_B_AUDITOR disable all triggers;
prompt Loading T_B_AUDITOR...
insert into T_B_AUDITOR (AUDITORID, NAME, ORGID, SEX, IDCARDNO, TITLE, PHONE, MOBILE, DESCRIBE, AUDITORRIGHT, AUDITORSTATUS, RECORDSTATUS, FIELD1, FIELD2)

这些东西该怎么撤消,大家的想法可能是我直接删除后直接在mysql中跑,但是您想一下假如要是您的备份文件很大很大呢,根本打不开就是。我碰到的sql备份有1G的,电脑不可着实是打不开没有办法只好,重新想其他的办法了。

在这里感谢下:ITPUB论坛的philip_zhong朋友,这里他给提供了一个步调,来处置处罚大数据量的迁徙工作。在这里说下我的利用感言啊,他提供了多种方式,shell脚本、windows下的bat启动、还有源步调。我都试过了,前两者没有调通,只好硬着头皮把他的源步调给跑一下,各种debug修改后终于调通了。很高兴……
这里必要提醒的是:
复制代码 代码如下:
static dataSyncDataSourceParameter dataSourceParameters;
static dataSyncSessionParameter sessionParameter;
//static final String configFileName = "config.properties";//这里是源步调中的参数,按照本身的必要举行配置
static final String configFileName = "config_oracle2mysql.properties";//这里是我的配置文件
/**
  * @param args
  */
public static void main(String[] args) {
  // initialize the parameters
  //String progPath = args[0];
  //String progPath = "D://work//MyEclipse 8.5//Workspaces//dataSync";E://workspace//oracletomysql//package
  String progPath = "E://workspace//oracletomysql//package";//这里大家注意下,是你的package的位置所在。
  String confFilePath = progPath + "//conf";
  if (setparameters(confFilePath)) {
   // start to call thread to sync the data
   syncData();
  }
}

config_oracle2mysql.properties配置文件:这里必要注意的是:ora_hash是个10g中才有的函数这里我们重新改变下:DBMS_UTILITY.GET_HASH_VALUE这个hash函数是在网上找了好长时间才有人提到的雷同与ora_hash的函数。反正这里我的明白就是为了多线程举行大数据量的搬运节约时间,作者才通过hash的方法举行控制。其他注意的地方我已经在步调里写出来一来提醒我注意二来给大家提个醒别犯我的错而浪费大家的时间。
复制代码 代码如下:
#for source database parameters
source.dataSource.initialSize=10
source.dataSource.maxIdle=20
source.dataSource.minIdle=5
source.dataSource.maxActive=100
source.dataSource.maxWait=120000
source.jdbc.driverClassName=oracle.jdbc.driver.OracleDriver
source.jdbc.url=jdbc:oracle:thin:@10.17.199.8:1521:lab1107
source.jdbc.username=lab1107
source.jdbc.password=lab1107
#Target sync data threadNum=source.database.threadNum
source.database.threadNum=10
#这里的auditorid必须是主键,ora_hash是在10g中利用的,我们的9i没办法用啊。
source.database.selectSql=select * from t_b_role where DBMS_UTILITY.GET_HASH_VALUE(roleid,1,#threadNum#)=?
#you can input many commands and split by ";"
source.database.sessionCommand=ALTER SESSION SET DB_FILE_MULTIBLOCK_READ_COUNT=128;
#for target jdbc parameters
target.dataSource.initialSize=10
target.dataSource.maxIdle=20
target.dataSource.minIdle=5
target.dataSource.maxActive=100
target.dataSource.maxWait=120000
target.jdbc.driverClassName=com.mysql.jdbc.Driver
target.jdbc.url=jdbc:mysql://10.5.110.239:3306/test?autoReconnect=true&characterEncoding=UTF-8
target.jdbc.username=root
target.jdbc.password=chen
#target.database.insertSql=insert into test2(PATHALIASID,PATH,CREATETIME,LASTMODIFIEDTIME,OBJECTPREFIX,PATHMD5ID,COLLIDESWITH) values(?,?,?,?,?,?,?)
target.database.insertSql=insert into T_B_ROLE(ROLEID,ROLENAME,ROLEDESC,ROLESTATUS,RECORDSTATUS,FIELD1,FIELD2,SORTNUM) values(?,?,?,?,?,?,?,?)这里必须是目标数据库中的现成的一张表。
target.database.commitNum=1000

详细的题目大家要是碰到了,可以一起交换下。

帖子地址: 

回复

使用道具 举报

分享
推广
火星云矿 | 预约S19Pro,享500抵1000!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

草根技术分享(草根吧)是全球知名中文IT技术交流平台,创建于2021年,包含原创博客、精品问答、职业培训、技术社区、资源下载等产品服务,提供原创、优质、完整内容的专业IT技术开发社区。
  • 官方手机版

  • 微信公众号

  • 商务合作