ResultSet 中找不到栏位名称 XXXX使用remapResults参数来解决

     今天和手机端联调一个功能,新老版本调用的sql语句是同一个,但是呢,他们调用旧版的时候,我后台就会包ResultSet 中找不到栏位名称 district_id的错误,我开启debug模式,把打印的sql语句放到数据库里面执行一下,发现是没问题的,确保不是数据库表中没有district_id字段,那么猜测就是ibatis的原因了。sql语句如下:

 注意截图中红框圈出的位置,因为新版本,他们是会传这个属性,而旧版是不传的,这就导致了,调用同一个id="queryNearByCm"语句,但是新老版本最后执行的语句是有不同的,所以我们需要设置remapResults="true"属性来解决这个错误。

ibatis的select标签有个属性remapResults,该属性默认值为false;当设置remapResults为"true"时:
iBATIS会在每次查询的时候内省查询结果来设置元数据,来保证返回恰当的结果。这个属性会造成一定的性能损失,所以要谨慎使用,只在你需要的时候使用--查询列发生变化,直接的,或者隐含的,检索的表发生变化。

<select id="queryNearByCm" resultClass="java.util.HashMap" parameterClass="java.util.Map" remapResults="true">

然后我的问题解决了,但是并不是所有的 ResultSet 中找不到栏位名称 的问题原因都是没设置remapResults导致的,我的原因是每次查询的sql是动态的,如果不是,可能是数据库表中没有这个字段或者返回类型(pojo)中没有getter/setter方法导致的,需要找准原因,以免错了方向,希望这篇博客能帮到你,有时间,点个赞。

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值