Oracle迁移到MySQL总结


这两个星期里一直都在忙于一件事儿,就是Oracle数据库的迁移问题。没有做的时候感觉这是一件十分轻松的事儿,可是等到实实在在去做去实现的时候,自己傻眼了。这种纠结啊,

在这里先说下遇到的问题:

1。数据库的表结构问题:数据类型不同需要解决varchar2------varchar、number-----int、date----datetime,建表的sql语句字段默认值、注释怎么解决。

2. oracle中没有所谓的敏感字段,可是mysql表中的敏感字段有好多。当时出错的时候很奇怪不知道是哪里错了。原来有个describe的字段是mysql的敏感字段。

这里我也是在网上找了一个现成的工具:oracletomysql,它是只能为我们迁移表结构。

3. oracle的备份sql没法正常的mysql中跑,一些to_date()函数,to_char()让人很是痛苦不知道怎么去代替,原因很简单在oracle的备份文件中有一堆的解释文字:

  1. prompt PL/SQL Developer import file  
  2. prompt Created on 2012-05-30 by chenbh  
  3. set feedback off  
  4. set define off  
  5. prompt Disabling triggers for T_B_AUDITOR...  
  6. alter table T_B_AUDITOR disable all triggers;  
  7. prompt Loading T_B_AUDITOR...  
  8. insert into T_B_AUDITOR (AUDITORID, NAME, ORGID, SEX, IDCARDNO, TITLE, PHONE, MOBILE, DESCRIBE, AUDITORRIGHT, AUDITORSTATUS, RECORDSTATUS, FIELD1, FIELD2)  

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

在这里感谢下philip_zhong朋友,

这里他给提供了一个程序,来处理大数据量的迁移工作。在这里说下我的使用感言啊,他提供了多种方式,shell脚本、windows下的bat启动、还有源程序。我都试过了,前两者没有调通,只好硬着头皮把他的源程序给跑一下,各种debug修改后终于调通了。很高兴……

这里需要提醒的是:

  1. static dataSyncDataSourceParameter dataSourceParameters;  
  2.     static dataSyncSessionParameter sessionParameter;  
  3.     //static final String configFileName = "config.properties";//这里是源程序中的参数,按照自己的需要进行配置  
  4.   
  5.     static final String configFileName = "config_oracle2mysql.properties";//这里是我的配置文件  
  6.   
  7.     /**  
  8.      * @param args  
  9.      */  
  10.     public static void main(String[] args) {  
  11.   
  12.         // initialize the parameters  
  13.         //String progPath = args[0];  
  14.         //String progPath = "D://work//MyEclipse 8.5//Workspaces//dataSync";E://workspace//oracletomysql//package  
  15.         String progPath = "E://workspace//oracletomysql//package";//这里大家注意下,是你的package的位置所在。  
  16.         String confFilePath = progPath + "//conf";  
  17.         if (setparameters(confFilePath)) {  
  18.             // start to call thread to sync the data  
  19.             syncData();  
  20.         }  
  21.     }  
  • 1
  • 2
  • 下一页

相关内容