欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Mybatis返回int或者Integer类型报错的解决办法

程序员文章站 2024-03-08 20:22:40
会报错如下: org.springframework.web.util.nestedservletexception: request processing failed...

会报错如下:

org.springframework.web.util.nestedservletexception: request processing failed; nested exception is org.apache.ibatis.binding.bindingexception: mapper method 'com.bill.springmybatis.dao.userdao.getuseridbyname attempted to return null from a method with a primitive return type (int).
    org.springframework.web.servlet.frameworkservlet.processrequest(frameworkservlet.java:894)
    org.springframework.web.servlet.frameworkservlet.doget(frameworkservlet.java:778)
    javax.servlet.http.httpservlet.service(httpservlet.java:734)
    javax.servlet.http.httpservlet.service(httpservlet.java:847)
    org.springframework.web.filter.characterencodingfilter.dofilterinternal(characterencodingfilter.java:88)
    org.springframework.web.filter.onceperrequestfilter.dofilter(onceperrequestfilter.java:76)

返回类型设置为封装类型integer或者基本类型int,都有可能出错

例如

<select id="querypaysum" resulttype="java.lang.integer" parametertype="map" > 
  select sum(p.cash_fee) from pay_info p 
  where 1=1 
     and p.trade_result_code = #{traderesultcode} 
</select>

我用的oracle  利用 nvl()函数 解决问题

<select id="querypaysum" resulttype="java.lang.integer" parametertype="map" > 
  select nvl(sum(p.cash_fee), 0) from pay_info p 
  where 1=1 
     and p.trade_result_code = #{traderesultcode} 
</select> 

补充:

下面给大家在看下:用 isnull(), nvl(), ifnull() and coalesce() 函数替换空值

在数据库操作中,往往要对一些查询出来的空值进行替换,如函数sum(),这个函数如果没有值会返回null,这是我们不希望看到的,

在mysql中我们可以这样来写:

select ifnull(sum(data),0) ...

在sqlserver中我们可以这样写:

select isnull(sum(data),0) ...

在oracle中我们可以这样写:

select nvl(sum(data),0) ...

对于所有数据库适用的方法可以这样写:

select coalesce(sum(data),0) ...

coalesce()用法:

 coalesce(value,...)

返回第一个不是null的值,如果参数列表全是null,则返回null

sselect coalesce(null,1);
    -> 1
select coalesce(null,null,null);
    -> null