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

来源:互联网 发布:书单推荐 知乎 编辑:程序博客网 时间:2024/05/16 17:38

由于业务需要,数据库要由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. <typeHandlerjavaType="CLOB"  javaType="java.lang.String"
      callback="org.springframework.orm.ibatis.support.ClobStringTypeHandler" /> 
但是没有作用

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

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


0 0
原创粉丝点击