iBatis会自动缓存每条查询语句的列名映射,对于动态查询字段或分页查询等queryForPage, queryForList,就可能产生“列名无效”、rs.getObject(object)异常错误。

当出现动态改变查询列,或者其他方式动态改变的时候,都需要设置remapResults="true"这个属性,因此不至于出现“列名无效”的错误。其实,这个错误抛出的地方是resultSet.getString(“xx”);方法,因为iBATIS保留了第一次的列名,所以第二次查询的时候resultSet获得的还是第一次保留下来的列名。



解决办法:

在SQL语句上加一个属性(remapResults)配置让每次执行都重新映射列名。

注:仅在可能被queryForPage()和queryForList()都调用、或者动态字段的SQL语句上加此属性。(以牺牲性能为代价,损耗很小很小)。

如下所示: 

<select id="queryPartyRole" parameterClass="long" resultClass="java.util.HashMap" remapResults="true"></select>

 

 
 

相关文章:

  • 2022-12-23
  • 2022-12-23
  • 2021-05-27
  • 2022-12-23
  • 2021-08-15
  • 2022-12-23
猜你喜欢
  • 2022-12-23
  • 2022-02-15
  • 2022-12-23
  • 2021-10-09
  • 2022-12-23
  • 2021-12-21
  • 2021-07-01
相关资源
相似解决方案