看到别人问的,自己在网上找的,没试过,备用,转载自【比特网】,转载请保留原文链接:http://soft.chinabyte.com/database/414/12349414.shtml

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

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

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

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

  3. oracle的备份sql没法正常的mysql中跑,一些to_date()函数,to_char()让人很是痛苦不知道怎么去代替,

  原因很简单在oracle的备份文件中有一堆的解释文字:

  [html]

  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的,电脑不行实在是打不开没有办法只好,从新想其他的办法了。

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

  这里需要提醒的是:

  [html]

  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的方法进行控制。其他注意的地方我已经在程序里写出来一来提醒我注意二来给大家提个醒别犯我的错而浪费大家的时间。

  [html]

  #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

  具体的问题大家要是遇到了,可以一起交流下。

  

转载于:https://www.cnblogs.com/defended/p/3569259.html

oracle迁移数据到mysql相关推荐

  1. rac ogg to mysql_GoldenGate从oracle迁移数据到mysql

    1软件简介 安装时应该选择最为稳定的安装版本,现在官方发布的版本主要为: Oracle GoldenGate 11.2.1.0.1 对应不同的数据库和版本,有不同的安装介质.下面是根据现网情况使用的两 ...

  2. Oracle同步数据到MySQL

    Oracle同步数据到MySQL 1.首先在TreeSoft数据库中配置两个数据源信息 2.配置数据同步任务,并执行任务 3.同步结果数据查看确认 4.目前TreeSoft支持以下数据同步方案 1.M ...

  3. 两台oracle怎样定期导表数据,定期从Oracle导数据至MySQL

    因部分项目需求,需要将Oracle中单表的数据定期导入至MySQL,注意此处对数据的时效性要求不高.要求高可以利用goldengate 首先,需要将visit表中的vid,userid,goodid, ...

  4. oracle迁移数据文件

    步骤如下: 1. 关闭数据库 shutdown abort 2.物理迁移数据文件 --这里演示将acptdat.dbf从/u01/app/oracle/oradata/orcl/下迁移到/u02/or ...

  5. oracle数据库抽取到gp,Oracle迁移数据到Greenplum

    端表结构 SQL> select dbms_metadata.get_ddl('TABLE','TAB_ORA','ZWC') from dual; CREATE TABLE "ZWC ...

  6. SQL Server 迁移数据到MySQL

    一.背景 由于项目开始时候使用的数据库是SQL Server,后来把存储的数据库调整为MySQL,所以需要把SQL Server的数据转移到MySQL:由于涉及的表比较多,所以想在MySQL中生成对应 ...

  7. 使用DataX从ORACLE同步数据到MYSQL

    [前提]安装python3.7 oracle版本:oracle 11g mysql版本:mysql5.7 1.下载DataX wget http://datax-opensource.oss-cn-h ...

  8. oracle迁移mysql_从自建Oracle迁移至RDS MySQL

    #本示例以名称为dtstest的数据库账号为例介绍授权命令,需要对PDB和CDB同时授权 #PDB授权示例: create user dtstest IDENTIFIED BY rdsdt_dtsac ...

  9. oracle mysql增量迁移_从自建Oracle迁移至RDS MySQL

    #本示例以名称为dtstest的数据库账号为例介绍授权命令,需要对PDB和CDB同时授权 #PDB授权示例: create user dtstest IDENTIFIED BY rdsdt_dtsac ...

最新文章

  1. php 字符串数组转数组对象_php怎么将数组转成对象?
  2. 谈谈CNN中的位置和尺度问题
  3. 2021年机器学习什么风向?谷歌大神Quoc Le:把注意力放在MLP上
  4. 机器学习基础专题:特征工程
  5. installshield学习笔记
  6. 第五届河南省大学生程序设计竞赛 题解
  7. 线程间通信及虚假唤醒
  8. Spring MVC 使用优化建议-缓存URL
  9. 协同遗漏的效果–使用简单的NIO客户端/服务器测量回送延迟
  10. Intel 64/x86_64/IA-32/x86处理器 - SIMD指令集 - SSE扩展(6) - 逻辑指令 比较指令
  11. 基于Keras的卷积神经网络(CNN)可视化
  12. java spring 配置词典_java之spring mvc之拦截器
  13. 五个案例“熄灭”Nginx漏洞隐患
  14. 面向对象——意图与逻辑(三)
  15. matlab 如何捕捉错误,【matlab|matlab运行错误捕捉方法】
  16. 2019最新机构Web前端培训全套项目实战(完整)
  17. Unity 安装Vuforia配置Android时遇到的问题及解决
  18. 通达信c语言编程,通达信编程实例100个;
  19. 最新TIOBE编程语言排行:C语言第一,Python反超Java,挤进第二
  20. total-vm anon-rss file-rss shmem-rss含义

热门文章

  1. svm中的数学和算法
  2. unity 模型销毁_Unity GameObject 销毁(Destroy)后的几种状态
  3. 系统学习机器学习之参数方法(一)
  4. DSP之时钟与定时器之一时钟发生器
  5. linux 引导原理 pdf,linux深度开发原理.pdf
  6. 满二叉树与完全二叉树入门
  7. Kafka日志刷新策略
  8. 二极管区分极性以及驱动原理
  9. 程序局部性(时间局部性与空间局部性)与循环展开原理详解
  10. CISCO 路由器(1)