码迷,mamicode.com
首页 > 编程语言 > 详细

Hibernate保存时报java.lang.ClassCastException

时间:2016-12-21 18:38:23      阅读:217      评论:0      收藏:0      [点我收藏+]

标签:cep   creat   uid   oracle   sql   exception   ora   sys   precision   

  今天改需求的是遇到一个问题,Hibernate执行save()方法时报错:java.lang.ClassCastException: java.lang.String cannot be cast to java.math.BigDecimal。在网上搜了一下,几乎所有的回答都是说实体、映射文件和表结构之间类型不对应。检查了好几遍也没有发现问题,只好想其它办法实现,结果在写其它方法代码的时候发现了问题所在。

  我通过Hibernate去往一张视图的里存数据,视图是查通过dblink连接的一个数据库的单表,服务直接访问的数据库主键都是varchar()类型,通过dblikn访问的远程数据库主键是Number类型,而我在写映射文件的时候没有检查就把主键生成策略写成了UUID,于是在插入的时候生成的String值要插入number类型的主键就会报错。所以把主键生成策略改成identity或sequence就可以解决。

  修改过程中发现hibernate配置主键生成策略可以直接调用远程数据库的sequence。

<id name="XXXX" type="java.math.BigDecimal">
  <column name="XXXX" precision="XX" scale="0">
    <comment>XXXX</comment>
  </column>
  <generator class="sequence" >
    <param name="sequence">dblikn.XXXX</param>
  </generator>
</id>

  顺便记录一下前面提的另外一种解决办法,就是通过Hibernate直接执行sql语句。

String sql = "insert into XXXX(select (select sys_guid() from dual),XXXX from XXXX@dblink)";
super.getCurrentSession().createSQLQuery(sql).executeUpdate();

  没有写完,基本就是这几行代码。采用不同主键生成策略都要在代码中写出相应的主键。比如sequence要调用已有的sequence。另外Oracle不支持identity,还是头一次知道。

Hibernate保存时报java.lang.ClassCastException

标签:cep   creat   uid   oracle   sql   exception   ora   sys   precision   

原文地址:http://www.cnblogs.com/fighter7/p/6208515.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!