org.hibernate.TypeMismatchException异常解决方案

 

org.hibernate.TypeMismatchException异常解决方案

 

今天刚开始做项目,第一个测试就出现了问题,抛的异常是TypeMismatchException (类型不匹配异常),

 

问题出现的原因:oracle数据库中创建id的时候id的类型是integer类型的,但是在用MyEclipse反向生成的时候,映射的实体类的id类型为BigDecimal类型的,如果在通过id查的时候,传的是int类型的,而实体类映射的是BigDecimal类型的,在dao中封装的方法的id也是integer的,类型肯定不会。

 

解决的方法:

(1)   我把封装的findById方法中的id的类型该成了Serializable类型的了

因为Serializable类型的在jdk5.0以上支持id为string、int类型的,原因是jdk1.5以上的支持了自动装箱的过程,int会自转换为Integer,而Integer是实现了Serializable的。

(2)   在传值的时候把BigDecimal类型转换为int类型的。

int bd = new BigDecimal(1).intValue();这句话来转换为int类型的,再通过装箱的过程去传值。

这样问题就解决了。

 

主要是类型匹配就ok了

 

通过这个异常,通过查手册,学习到了一点知识:

 

当在数据库中指定类型的时候,如果指定的number(4),则在反向的时候就是Short类型的,也就是说number根据不同的字节,反向的值的类型不同,但是都是Number的子类。

 

Number 的子类必须提供将表示的数值转换为 byte、double、float、int、long 和 short 的方法。

抽象类 Number 是 BigDecimal、BigInteger、Byte、Double、Float、Integer、Long 和 Short 类的超类。

 

 

下面的是对Serializable使用的解释,从网上查的:

对象序列化是为了反序列化用的
比如将一个对象写入到文件,或者作为流的形式传给第三方,那么这个类必须实现Serializable接口,并且定义一个私有的常量SerializableID,不然就不能从文件中读取对象了,接收方也没法还原这个对象

 

或者:

 

不是说特定或好处,是有作用的

比如你定义了一个Student类,里面定义了一个SerializableID=5,序列化后传给我,我将其存到数据库以后再使用

若干天后,系统升级,你在Student类加了一个字段String address,如果Student里没有定义SerializableID或者SerializableID不一样了,我存在数据库里的Student对象就反序列化不回来了

如果定义了SerializableID,即使你在Student里加了一个属性,我存在数据库的对象少一个属性,但还是可以反序列化回来的,只是新加的那个属性值为null而已

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值