Mybatis返回int或者Integer类型报错的解决办法
会报错如下:
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