Mybatis_java.lang.UnsupportedOperationException异常

1. 发生异常的背景
 情景:
好惭愧啊,最近居然犯了两次不该犯的错误。都怪自己不够细心。刚刚好自己在Mybatis这一模块上,根本没有记录多少,就哪来当做博文的材料吧。

我们在使用Mybatis的过程中,常常需要返回一个List集合。这个时候,如果我们一不小心写错了返回类型,则会报一个java.lang.UnsupportedOperationException错误,详情如下:

// 所报的主要异常如下:
org.mybatis.spring.MyBatisSystemException: 
nested exception is org.apache.ibatis.exceptions.PersistenceException:
Cause: java.lang.UnsupportedOperationException
        at org.mybatis.spring.MyBatisExceptionTranslator.translateExceptionIfPossible(MyBatisExceptionTranslator.java:79)
        at org.mybatis.spring.SqlSessionTemplate$SqlSessionInterceptor.invoke(SqlSessionTemplate.java:447)
        at com.sun.proxy.$Proxy138.selectList(Unknown Source)
        at org.mybatis.spring.SqlSessionTemplate.selectList(SqlSessionTemplate.java:231)
        at org.apache.ibatis.binding.MapperMethod.executeForMany(MapperMethod.java:137)
        at org.apache.ibatis.binding.MapperMethod.execute(MapperMethod.java:75)
        at org.apache.ibatis.binding.MapperProxy.invoke(MapperProxy.java:53)
        at com.sun.proxy.$Proxy150.existIccidList(Unknown Source)

 万恶的错误源如下:

<select id="queryIccidByUserId" parameterType="String" resultType="java.util.List">
      select iccid from iot_base where user_id = #{userId,jdbcType=VARCHAR}
</select>

对应的Mapper层接口方法如下:

 public List<String> queryIccidByUserId(@Param(userId) String userId);

然后在运行到该方法的时候会报错。

 
2. 原因以及解决方法
原因是我在XML配置的resultType错误,配置应该是集合中元素的类型。例如在我这个案例中,配置的就应该是String

  • 解决方法:解决方法

如果返回的类型是集合,那resultType中设置的类型应该是集合中的元素类型,不能是设置为集合。

发布了204 篇原创文章 · 获赞 69 · 访问量 19万+

猜你喜欢

转载自blog.csdn.net/pseudonym_/article/details/100118426