Null value was assigned to a property of primitive type原因及解决方法
参考1
报错:
原因:查询出来的数据有null值,null值没办法赋double
错误地方:
解决方法:
添加:IFNULL(,)
修改后:
ok解决
参考2
在action请求数据的过程中报出"Null value was assigned to a property of primitive type setter of"错误,搜索之后发现是因为数据库里相应的字段为NULL。
例如:
Java代码
<property name="maxborrow" column="maxborrow" length="11" type="java.lang.Integer" ></property>
其中的类型为hibernate类型,在生成的类中,printTime字段为long类型,为基本类型,不能为NULL.
解决方法:
第一种:数据库字段不设置为空;
第二种:手动修改映射文件,printTime使用Java类型Long,即type="java.lang.Long",Book类中的字段也要改为Long。同理,int为Integer.
第三种:在反向工程时使用Java类型,而不是hibernate类型。
注:上次我的一个字段数据库类型为int且值为null, hibernate配置文件中为java.lang.Integer, 造成类型转换错误
正确做法:数据库(mysql)字段类型设为integer,hibernate配置为java.lang.integer,javabean也设为integer
或者给数据库这个int类型赋初识值0,1,2,...hibernate和javabean设为int