JAVA项目将 Oracle 转 MySQL 数据库转换(Hibernate 持久层)
项目开发时用的是Oracle数据库,但为了更好的做分布式,做集群,我们要将数据库转成 MySQL!
在数据库迁移中首先要做的事是将 Oracle 的表结构以及数据 克隆到 MySQL 数据库。
这点不多说,有很多工具可以实现,网上大神也给出了相应指导。
重点说说后台代码:
一、在 Oracle 数据库中 所有的表明、字段名都是大写,而工具将表结构转到 MySQL 之后表明名成了小写字母,
而在MySQL里列名不区分大小写,但是表名区分大小写(t_xx_paper 表 不是 T_XX_PAPER 表),
所以要将项目中所有的大写表名替换成小写。
1、去数据库复制小写表名 (t_xx_paper 为例)

2、在开发工具里(我用的是 Eclipse)全局替换: Ctrl + H 快捷键

上面选中 file search, containing text 里面输入将被替换的内容 : T_XX_PAPER, 然后 Replace...
3、在搜索栏下面可以看到整个项目有几个 ‘T_XX_PAPER’ 以及出现的位置, 在 Raplace Text Matches 框的 with 栏里输入要替换成的小写 :t_xx_paper
点击 OK 就完成了, 其他表也按上述步骤执行即可
二、在 Oracle 数据库中用的是序列作为主键,而在 MySQL中用不了。我这里用了 Hilo 代替
在上一篇博客给了说明,这里一笔带过: http://www.cnblogs.com/linnuo/p/7085688.html
我在 Oracle 的自增主键用的是 NUMBER 类型,转到 MySQL 后成了 decimal 类型
不过这两种类型都不影响映射成 java 的 Long 类型。
将所有带有主键映射的 hibernate hbm.xml 文件的 序列sequence自增 替换成 Hilo 自增
Oracle:
<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
<class name="com.gzewell.ucomweb.domain.Paper" table="t_xx_paper">
<property name="title" type="java.lang.String">
<column name="TITLE" length="256" />
</property>
<property name="imgTitle" type="java.lang.String">
<column name="IMG_TITLE" length="256" />
</property>
<property name="content" type="java.lang.String">
<column name="CONTENT"/>
</property>
<property name="image" type="java.lang.String">
<column name="IMAGE" length="256" />
</property>
<property name="author" type="java.lang.String">
<column name="AUTHOR" length="32" />
</property>
<property name="authorId" type="java.lang.Long">
<column name="AUTHOR_ID"/>
</property>
<property name="createTime" type="java.util.Date">
<column name="CREATE_TIME" length="0" />
</property>
<property name="auditor" type="java.lang.String">
<column name="AUDITOR" length="32" />
</property>
<property name="auditTime" type="java.util.Date">
<column name="AUDIT_TIME" length="0" />
</property>
<property name="lastUpdateTime" type="java.util.Date">
<column name="LAST_UPDATE_TIME" length="0"/>
</property>
<property name="status" type="java.lang.Long">
<column name="STATUS" length="1" />
</property>
<property name="auditorId" type="java.lang.Long">
<column name="AUDITOR_ID"/>
</property>
</class>
</hibernate-mapping>
MySQL:
<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
<class name="com.gzewell.ucomweb.domain.Paper" table="t_xx_paper">
<id name="rowId" column="ROW_ID" type="java.lang.Long">
<generator class="hilo">
<param name="table">hibernate_hilo</param>
<param name="column">next_hi</param>
<param name="max_lo">100000000</param>
</generator>
</id>
<property name="title" type="java.lang.String">
<column name="TITLE" length="256" />
</property>
<property name="imgTitle" type="java.lang.String">
<column name="IMG_TITLE" length="256" />
</property>
<property name="content" type="java.lang.String">
<column name="CONTENT"/>
</property>
<property name="image" type="java.lang.String">
<column name="IMAGE" length="256" />
</property>
<property name="author" type="java.lang.String">
<column name="AUTHOR" length="32" />
</property>
<property name="authorId" type="java.lang.Long">
<column name="AUTHOR_ID"/>
</property>
<property name="createTime" type="java.util.Date">
<column name="CREATE_TIME" length="0" />
</property>
<property name="auditor" type="java.lang.String">
<column name="AUDITOR" length="32" />
</property>
<property name="auditTime" type="java.util.Date">
<column name="AUDIT_TIME" length="0" />
</property>
<property name="lastUpdateTime" type="java.util.Date">
<column name="LAST_UPDATE_TIME" length="0"/>
</property>
<property name="status" type="java.lang.Long">
<column name="STATUS" length="1" />
</property>
<property name="auditorId" type="java.lang.Long">
<column name="AUDITOR_ID"/>
</property>
</class>
</hibernate-mapping>
1、我这里主键用的全都是 ROW_ID 映射成 java 的 Long类型,这就简单了。 全局查找:<id name="rowId" type="java.lang.Long">

search 所有的 主键 ROW_ID 都会显示在 search 框里

2、逐一点开search框里的存在 <id name="rowId" type="java.lang.Long"> 的文件,将主键 ID
<id name="rowId" type="java.lang.Long">
<column name="ROW_ID" scale="0" precision="16"/>
<generator class="seqhilo"/>
</id>
改成如下即可:
<id name="rowId" column="ROW_ID" type="java.lang.Long">
<generator class="hilo">
<param name="table">hibernate_hilo</param>
<param name="column">next_hi</param>
<param name="max_lo">100000000</param>
</generator>
</id>
JAVA项目将 Oracle 转 MySQL 数据库转换(Hibernate 持久层)的更多相关文章
- Java在线备份和还原MySQL数据库。
2018年6月29日14:00:48 阅读数:1534 今天整了整整一整天,终于使用Java在线备份和还原MySQL数据库了,哎,备份倒是很快,就是在还原的时候遇到了一个问题,也不报错,结果将sql语 ...
- 在oracle配置mysql数据库的dblink
本文介绍如何在oracle配置mysql数据库的dblink:虽然dblink使用很占资源:俗称“性能杀手”.但有些场景不得不使用它.例如公司使用数据库是oracle:可能其他部门或者CP合作公司使用 ...
- java中用activiti插件连接mysql数据库,自动建表过程中,在配置mysql架包路径“org.activiti.engine.ActivitiException: couldn't check if tables “
java中用activiti插件连接mysql数据库,出现错误: org.activiti.engine.ActivitiException: couldn't check if tables are ...
- 懒要懒到底,能自动的就不要手动,Hibernate正向工程完成Oracle数据库到MySql数据库转换(含字段转换、注释)
需求描述 需求是这样的:因为我们目前的一个老项目是Oracle数据库的,这个库呢,数据库是没有注释的,而且字段名和表名都是大写风格,比如 在代码层面的po呢,以前也是没有任何注释的,但是经过这些年,大 ...
- JDBC(Java项目使用Oracle数据库)
Java项目中使用Oracle数据库(Eclipse) 前言 这学期选了Oracle数据库这门课,于是自己下载了Oracle11gR2版本的数据库.在这之前我一直用的是MySQL.虽然两者教程差不多, ...
- JAVA使用JDBC连接,修改MySQL数据库(比较乱)
原文地址1(连接MySQL图文) : http://www.cnblogs.com/GarfieldEr007/p/5746137.html 原文地址2 (修改MySQL图文): http://www ...
- SQL Server 和 Oracle 以及 MySQL 数据库
推荐:https://www.zhihu.com/question/19866767 三者是目前市场占有率最高(依安装量而非收入)的关系数据库,而且很有代表性.排行第四的DB2(属IBM公司),与Or ...
- oracle迁移mysql数据库注意
oracle转mysql修改: . substr() substr( string , 0, 10) 这里测试 必须从 第一位获取 既是 substr(string , 1 , 10)2. to_ch ...
- oracle迁移mysql数据库注意(转)
oracle转mysql修改: 1. substr() substr( string , 0, 10) 这里测试 必须从 第一位获取 既是 substr(string , 1 , 10)2. to_c ...
随机推荐
- 在TFS中使用Git Tags(标签或标记),实现代码的版本管理
一.概述: 与TFVC中标记(Label)一样,Git的标签(Tag)也是TFS系统的代码管理中非常重要的一个版本管理工具.使用标签,我们可以每个时间点的代码注上一个通俗.并且容易记忆的名称(例如标签 ...
- 如何使用linq读取DataTable集合?AsQueryable() 和 AsEnumerable()区别?
一.准备工作 引入linq和data 相关的using命名空间 DataTable dt=new DataTable();//dt的来源可以是多个地方,比如:数据库,Excel等等.我这里使用Exce ...
- 【加密算法】AES
一.简介 AES(Advanced Encryption Standard):高级加密标准,是下一代的加密算法标准,速度快,安全级别高. 用AES加密2000年10月,NIST(美国国家标准和技术协会 ...
- asp.net core 使用identityServer4的密码模式来进行身份认证(一)
IdentityServer4是ASP.NET Core的一个包含OpenID和OAuth 2.0协议的框架.具体Oauth 2.0和openId请百度. 前言本博文适用于前后端分离或者为移动产品来后 ...
- .NET Core 和 .NET .Framework 速度比较
废话不多说! 一下是 .NET core 和 .NET framework 速度对比. 两者使用最慢的冒泡排序算法: 排序10万条数据 次数 .NET CORE(耗时) .NET framework ...
- c# WPF客户端调用WebAPI并转换成List
利用HttpClient.JsonConvert实现. 引用Newtonsoft.Json.dll和System.Net.Http. 举个例子:从webapi中获取设备列表. public parti ...
- 机器学习、深度学习、和AI算法可以在网络安全中做什么?
本文由 网易云发布. 本文作者:Alexander Polyakov,ERPScan的首席技术官和联合创始人.EAS-SEC总裁,SAP网络安全传播者. 现在已经出现了相当多的文章涉及机器学习及其保 ...
- 世界线(bzoj2894)(广义后缀自动机)
由于春希对于第二世代操作的不熟练,所以刚使用完\(invasion process\)便掉落到了世界线之外,错综复杂的平行世界信息涌入到春希的意识中.春希明白了事件的真相. 在一个冬马与雪菜同时存在的 ...
- flask源码解析之session
内容回顾 cookie与session的区别: 1. session 是保存在服务端的键值对 2. cookie 只能保存4096个字节的数据,但是session不受限制 3. cookie保存在浏览 ...
- Mybatis的cache
相关类:org.apache.ibatis.executor.CachingExecutor 相关代码: public <E> List<E> query(MappedStat ...