通过数据库迁移总结的MySql与Oracle主要区别

由于业务需要,数据库要由MySql迁移到Oracle上来,一边迁移,一边总结MySql与Oracle的区别,以及在迁移过程中的要点

一、数据库部分

(1)表之间的区别

          a .数据类型之间的差别

数据库类型之间的差别主要体现在日期,以及长数据类型.

                在MySql中存在datetime类型,而Oracle只有time类型,关键在于数据导出之后,mySql可以自己将日期类型的char转换为datetime,所以insert语句直接是char类型,但是Oracle更为严格,在转换过程中并不支持这样,需要在insert语句中,变成to_date('','yyyy-mm-dd hh24:mi:ss')

                另一种就是longtext,网上一种说法是longtext转成Oracle中Blob,但是我更倾向于转换成clob,原因是在mySql导出的insert语句中,插入blob需要在insert前假如 to_blob() ,而且在Orm层也有干扰,所以最好的办法是转换成clob

二、ORM层

       由于ORM层使用的是iBatis,也有一些问题要注意

       首先是数据序列化,序列化中Blob,Clob序列化是大问题,Clob可以序列化为String类型,工程是通过typeAlias转换的,无法显式地指定jdbc类型和转换类型,最后决定在sqlMapConfig里使用

  1. <typeHandler javaType="CLOB"  javaType="java.lang.String"
      callback="org.springframework.orm.ibatis.support.ClobStringTypeHandler" /> 
但是没有作用

最后是查到 删掉javaType="CLOB"

然后就生效了,具体原因还未探索


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值