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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值