Mybatis:遍历map,list

温故而知新! 

List

Java代码

List<Person> selectByNames(@Param("names") List<String> names);

mapper 

 <select id="selectByNames" resultType="com.panda.mpt.pojo.Person">
        select name,age from person where name in
    <foreach collection="names" separator="," open="(" close=")" index="index" item="item">
          #{names}
    </foreach>
</select>

item:当前遍历的元素值。index:从0开始的序号。

Map

<foreach>不但支持list,也支持map

Java代码

List<Person> selectByNames2(@Param("maps") Map names);

mapper 

<select id="selectByNames2" resultType="com.panda.mpt.pojo.Person">
        select * from person where
        <foreach collection="maps.entrySet()" separator="or" index="index" item="item">
            ( name = #{index} and age = ${item} )
        </foreach>
</select>

index:entry的key,item:entry的value

separator:每次遍历后插入sql后的值

open: foreach开始是插入sql的语句

close:foreach结束后插入sql的语句

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值