Mybatis批量查询

网上很多例子都是mybatis批量查询的时候都是用in子句,但是,如果一个查询的参数封装成一个对象,并且查询参数又是一个集合的时候,该如何写呢

下面是一个例子:

想使用:

List<CDMAView> list = dao.selectByList(listP);

接口这样写:



public interface CDMADao {

public List<CDMAView> selectByList(List<CDMASearchParameter> list);

//CDMASearchParameter是一个实体对象,专门用来封装查询参数,返回一个封装了vo的集合对象
}

xml文件这样写:

<select id="selectByList" parameterType="java.util.List" resultMap="cdmaResult">//这里返回的结果自然也是一个集合
select * from cdma where
<foreach collection="list" separator="or" open="(" close=")" index="index" item="item">
mnc=#{item.sid} and lac=#{item.nid} and cell=#{item.bid}
</foreach>
</select>
<resultMap type="cn.juhe.vo.CDMAView" id="cdmaResult">
<result property="sid" column="mnc"/>
<result property="nid" column="lac"/>
<result property="bid" column="cell"/>
<result property="lon" column="lng"/>
<result property="lat" column="lat"/>
<result property="o_lon" column="o_lng"/>
<result property="o_lat" column="o_lat"/>
<result property="raggio" column="precision"/>
<result property="address" column="address"/>
</resultMap>


为什么要突出or呢,可以看控制台打印的失去了语句:

DEBUG cn.juhe.dao.CDMADao.selectByList - ==>  Preparing: select * from cdma where ( mnc=? and lac=? and cell=? or mnc=? and lac=? and cell=? ) 

可以先把这sql语句在数据库中测试一下,看看能不能直接查询出结果,如果可以,那肯定就没有问题了

重点是,在使用foreach的时候要拼接到sql语句

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

micro_cloud_fly

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值