Hibernate保存时报java.lang.ClassCastException
Posted 小柒_Zombie
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Hibernate保存时报java.lang.ClassCastException相关的知识,希望对你有一定的参考价值。
今天改需求的是遇到一个问题,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 [email protected])"; super.getCurrentSession().createSQLQuery(sql).executeUpdate();
没有写完,基本就是这几行代码。采用不同主键生成策略都要在代码中写出相应的主键。比如sequence要调用已有的sequence。另外Oracle不支持identity,还是头一次知道。
以上是关于Hibernate保存时报java.lang.ClassCastException的主要内容,如果未能解决你的问题,请参考以下文章
spring和hibernate整合时报sessionFactory无法获取默认Bean Validation factory
spring整合hibernate时报错:org.hibernte.engine.transaction.spi.transactioncontext
将hibernate.cfg.xml文件都放到spring中时报错
使用hibernate从一方获取多方信息时报错:org.hibernate.LazyInitializationException: failed to lazily initialize a col
Hibernate映射数据库中longtext类型属性时报错No Dialect mapping for JDBC type: -1的解决方案