今天和手机端联调一个功能,新老版本调用的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方法导致的,需要找准原因,以免错了方向,希望这篇博客能帮到你,有时间,点个赞。