Mybatis resultType异常

当需要查询返回 List<String> 

1

2

3

<select id="getByIds"  parameterType="java.lang.String"  resultType="java.util.List">

    SELECT l.label_name FROM label l WHERE l.id IN(#{labelIds})

  </select>

1

返回值定义为 resultType="java.util.List" <br><br>会报错,需要将返回值改为:resultType="java.lang.String"

当需要查询返回 List<Long>

也可以这样定义 

resultType="java.lang.long"

resultType:

1、基本类型  :resultType=基本类型

2、List类型:   resultType=List中元素的类型

3、Map类型    单条记录:resultType =map

                          多条记录:resultType =Map中value的类型

mybatis查询的返回类型为基础类型(int、long等),但结果为null时的异常解决

以 resultType=“int” 为例,试过把resultType由 int 改为 Integer ,但还是不行,下面的办法,从sql语句入手,使用数据库的空值转换函数,完美解决:

mysql:

SELECT IFNULL(MAX(SORT),0)AS sort FROM web_d_info

oracle:

SELECT nvl(MAX(SORT),0) as sort FROM web_d_info
 

猜你喜欢

转载自blog.csdn.net/Chen_XiRan/article/details/85209316