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
中设置的类型应该是集合中的元素类型,不能是设置为集合。