java方法返回int报错_【java】Mybatis返回int类型为空的时候报错

一、前言

在往常敲代码的时候没有留意过int和Integer的区别,今天在敲代码的时候,ORM框架使用的是Mybatis,一个简单的查询,返回查询的条数。当查询为null的时候,就报错了。

二、报的错误

试图从具有原始返回类型(int)的方法返回null

org.apache.ibatis.binding.BindingException: Mapper method 'com.dmsdbj.itoo.basicInfo.dao.RoomDao.selectSumCountCapacity attempted to return null from a method with a primitive return type (int).

at org.apache.ibatis.binding.MapperMethod.execute(MapperMethod.java:93) at org.apache.ibatis.binding.MapperProxy.invoke(MapperProxy.java:59) at com.sun.proxy.$Proxy35.selectSumCountCapacity(Unknown Source) at com.dmsdbj.itoo.basicInfo.service.impl.PlaceManageServiceImpl.selectSumCountCapacity(PlaceManageServiceImpl.java:858) at com.dmsdbj.itoo.basicInfo.service.impl.PlaceManageServiceImpl$$FastClassBySpringCGLIB$$c31f6b08.invoke() at org.springframework.cglib.proxy.MethodProxy.invoke(MethodProxy.java:204) at org.springframework.aop.framework.CglibAopProxy$DynamicAdvisedInterceptor.intercept(CglibAopProxy.java:669) at com.dmsdbj.itoo.basicInfo.service.impl.PlaceManageServiceImpl$$EnhancerBySpringCGLIB$$49d6b6e3.selectSumCountCapacity() at com.dmsdbj.itoo.basicInfo.facade.impl.PlaceManageFacadeImpl.selectSumCountCapacity(PlaceManageFacadeImpl.java:439) at com.dmsdbj.itoo.basicInfo.facade.test.PlaceManageFacadeTest.testselectSumCountCapacity_false(PlaceManageFacadeTest.java:342) at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) at java.lang.reflect.Method.invoke(Method.java:497) at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:50) at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12) at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:47) at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17) at org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.java:26) at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:325) at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:78) at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:57) at org.junit.runners.ParentRunner$3.run(ParentRunner.java:290) at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:71) at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:288) at org.junit.runners.ParentRunner.access$000(ParentRunner.java:58) at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:268) at org.junit.runners.ParentRunner.run(ParentRunner.java:363) at org.junit.runner.JUnitCore.run(JUnitCore.java:137) at com.intellij.junit4.JUnit4IdeaTestRunner.startRunnerWithArgs(JUnit4IdeaTestRunner.java:68) at com.intellij.rt.execution.junit.IdeaTestRunner$Repeater.startRunnerWithArgs(IdeaTestRunner.java:51) at com.intellij.rt.execution.junit.JUnitStarter.prepareStreamsAndStart(JUnitStarter.java:237) at com.intellij.rt.execution.junit.JUnitStarter.main(JUnitStarter.java:70)

三、解决方案

Mybatis的mapper文件的返回类型resultType为Integer:

返回类型设置为封装类型Integer而不是基本类型int。

SELECT

IFNULL( SUM(room_capacity),0)

FROM

t_room

WHERE

roomType_id = #{roomTypeId}

AND id NOT IN (

#{item}

)

Service之间的返回值也是Ingeger:

/** * 查询未安排考场的教室总容量-王雷-2017年9月1日15:09:25 *@param roomIds *@param roomTypeId *@return */

public Integer selectSumCountCapacity(List roomIds ,String roomTypeId){

if (roomIds==null||roomTypeId==""){

logger.debug("查询未安排考场的教室总容量,已使用的房间id为空,将查询所有的房间容量");

}

return roomDao.selectSumCountCapacity(roomIds, roomTypeId);

}

另外:若遇到该问题,可使用MySQL的IFNULL函数和MAX函数,将返回的NULL值转换为0。例如,可将上述SQL语句改为:

SELECT IFFULL(MAX(name),0) AS name FROM user WHERE id = #{id}

四、int和integer的区别

以前一直没有思考,为啥要有一个int还要有一个integer。实际上:

1. Ingeter是int的包装类,int的初值为0,Ingeter的初值为null;

2.初始化的时候,int i =1;Integer i= new Integer(1);(要把integer 当做一个类看);但由于有了自动装箱和拆箱使得对Integer类也可使用:Integer i= 1;

3.int 是基本数据类型(面向过程留下的痕迹,不过是对java的有益补充),Integer 是一个类,是int的扩展,定义了很多的转换方法

4.Integer是对象,用一个引用指向这个对象,而int是基本类型,直接存储数值。

五、小结

java中的数据类型分为基本数据类型和复杂数据类型,int是基本数据类型,integer是复杂数据类型,复杂基本类型也就是一个类,所以初始化为null。

从基本知识出发,能更加夯实自己的基础。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在MyBatis中,当我们使用int或者Integer类型作为返回类型时,有时会出现报错的情况。这是因为MyBatis在进行结果映射时,需要将数据库中的数据类型Java中的数据类型进行转换,而存在类型转换不匹配的情况。 要解决这个问题,可以采取以下几种方式: 1. 使用别名:在映射文件中,为返回结果的属性设置别名,确保与数据库中对应的字段类型一致。例如,若数据库中的字段类型INT,可以在映射文件中设置为<result column="columnName" property="propertyName" jdbcType="INTEGER"/>,其中jdbcType属性为指定的数据库字段类型。 2. 使用ResultType注解:在Mapper接口中,使用@ResultType注解来指定返回结果的数据类型。例如,若返回类型int,可以在方法上添加@ResultType(Integer.class)注解。 3. 使用映射器接口方法返回类型:如果方法返回类型Integer而不是intMyBatis会自动进行类型转换,避免类型不匹配的问题。 4. 使用TypeHandler:如果上述方法仍然无法解决问题,可以自定义TypeHandler来处理类型转换。TypeHandler可以将数据库中的数据类型转换为Java中的对应类型,确保一致。 总之,通过以上几种方式,我们可以解决MyBatis返回int或者Integer类型报错的问题。根据具体情况选择其中合适的方法来解决类型转换不匹配的问题,确保数据库查询结果能正确映射到Java对象中。 ### 回答2: 当在使用MyBatis时,如果遇到返回intInteger类型报错的问题,可能是以下几个原因所导致的: 1. Mapper接口或XML文件中未正确配置返回类型:在Mapper接口的方法中,应该使用int或者Integer作为返回类型,并在对应的XML文件中配置正确的返回类型。 2. SQL语句中未使用正确的函数进行计算:如果在SQL语句中进行计算并返回intInteger类型,应该使用合适的计算函数,比如COUNT、SUM等,并且在对应的XML文件中配置正确的结果映射。 3. 数据库字段类型返回类型不匹配:如果数据库中存储的数据类型返回类型不匹配,会导致报错。确保数据库字段类型返回类型一致,或者在XML文件中使用合适的类型转换器进行转换。 解决这些报错方法如下: 1. 确认Mapper接口和XML文件中正确配置了返回类型。在Mapper接口方法中使用intInteger作为返回类型,然后在XML文件中配置正确的返回类型。 2. 检查SQL语句中是否正确使用了计算函数,并在XML文件中配置正确的结果映射。 3. 确保数据库字段类型返回类型相匹配,若不匹配则进行类型转换。可以使用MyBatis类型处理器或者自定义类型转换器来进行转换操作。 总结:在使用MyBatis返回intInteger类型报错,需要检查Mapper接口和XML文件中的返回类型配置是否正确,是否使用了合适的计算函数,以及数据库字段类型是否与返回类型匹配,并进行相应的修改和调整。 ### 回答3: 当使用MyBatis进行数据持久化操作时,有时会遇到返回intInteger类型的结果报错的情况。这可能是因为MyBatis在映射数据库结果时,无法正确地将查询结果映射到intInteger类型的变量上。为了解决这个问题,可以采取以下几种方法: 1. 修改映射文件中的返回类型:在对应的映射文件(通常是mapper.xml文件)中,将返回类型intInteger修改为对应的实体类类型。这样可以确保MyBatis能够正确地将查询结果映射到实体类对象上。 2. 使用resultType属性:在查询语句中添加resultType属性,指定返回结果的类型。例如,如果要返回整数类型,可以将resultType设置为java.lang.Integer。 3. 使用selectOne方法:如果只需要返回单个整数类型的结果,可以使用selectOne方法进行查询。该方法会直接返回查询结果,不需要进行映射。 4. 使用自定义返回类型处理器:可以编写一个自定义的类型处理器,用于处理intInteger类型返回结果。在自定义类型处理器中,可以指定将intInteger类型的结果映射为其他类型,如String或Double。 综上所述,解决MyBatis返回intInteger类型报错方法包括修改返回类型、使用resultType属性、使用selectOne方法或编写自定义的类型处理器。根据具体的情况选择适合的方法来解决该问题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值