今天在开发过程中一直好好的,可是突然程序报错了,错误信息如下:
exception setting property value with CGLIB (set hibernate.cglib.use_reflection_optimizer=false for more info) setter of com.common.business.staffing.common.po.EmployeeInfoPO.setJobClass
最开始我以为是没有setter方法,结果文件中有这个方法。
配置文件:
javax.servlet.ServletException: exception setting property value with CGLIB (set hibernate.cglib.use_reflection_optimizer=false for more info) setter of XXX
错误提示信息:
javax.servlet.ServletException: exception setting property value with CGLIB (set hibernate.cglib.use_reflection_optimizer=false for more info) setter of XXX
一般是因为null造成的。例如:一个int映射到数据库中,但从数据库读取时是null值这样就会出现此中异常
解决办法:
1、手动修改数据库,修改该字段中的null值,建表的时候给这个字段一个默认值,default=0。
2、对于一些数字项包含null,定义该项时必须使用wrapper类型,而不能是primitive类型,例如使用Integer等,而不能是int 否则会抛出exception! 如果允许为空的字段做一包装(int-->Integer,long-->Long,double--->Double等),如果不是为空的字段,建表的时候给这个字段一个默认值(default=0),然后修改该表中的字段为你默认的值
补充下,主要是数据库中的long ,int等原始数据类型为null,如果hibernate映射文件的字段类型为long,由于null不能赋值给原始类型,所以报错。解决方法1:让字段不为空,方法2:把映射文件的字段改为对象。如long 改为 Long ,int 改为Integer,
double改为 Double
例子:
(原先)
<property name="cityid" type="long" >
<column name="CITYID" precision="22" scale="0" />
</property>
改为:
<property name="cityid" type="java.lang.Long" not-null="true">
<column name="CITYID" precision="22" scale="0" />
这样的好处是安全。缺点是在po中也要用LONG,需要转换为long。