Null value was assigned to a property of primitive type原因及解决方法

参考1

报错:

img

原因:查询出来的数据有null值,null值没办法赋double

错误地方:

img

解决方法:

添加:IFNULL(,)
修改后:img

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

posted @ 2022-09-03 21:35  哩个啷个波  阅读(497)  评论(0编辑  收藏  举报