Mybatis之foreach用法 List和Array,对象

向sql传递数组或List,mybatis使用foreach解析

foreach元素的属性主要有itemindexcollectionopenseparatorclose

  • item集合中元素迭代时的别名,该参数为必选。

 

  • index:在list和数组中,index是元素的序号,在map中,index是元素的key,该参数可选

 

  • openforeach代码的开始符号,一般是(close=")"合用。常用在in(),values()时。该参数可选

 

  • separator:元素之间的分隔符,例如在in()的时候,separator=","会自动在元素中间用“,“隔开,避免手动输入逗号导致sql错误,如in(1,2,)这样。该参数可选。

 

  • close: foreach代码的关闭符号,一般是)open="("合用。常用在in(),values()时。该参数可选。
  • collection:

        foreach的时候最关键的也是最容易出错的就是collection属性,该属性是必须指定的,但是在不同情况 下,该属性的值是不一样的,主要有一下3种情况:

    1. 如果传入的是单参数且参数类型是一个List的时候,collection属性值为list
    2. 如果传入的是单参数且参数类型是一个array数组的时候,collection的属性值为array
    3. 如果使用Map封装了,collection的属性值为对应的Key

1、array数组的类型

UserMapper.java


List<User> findUser_array(int [] ids)throws Exception;

UserMapper.xml

<!--单参数array数组的类型-->

  <select id="findUser_array" resultType="com.xiaomin.page.pojo.User">

    select * from sys_user

        <where>

            <foreach collection="array" item="item" open="and id in(" separator="," close=")">

                 #{item}

            </foreach>

        </where>

  </select>

Controller.java

@RequestMapping("/findUser_array")

  @ResponseBody

  public List<User> foreach_test()throws Exception{

    int [] ids=new int[]{1,2,3};

    List<User> list = userMapper.findUser_array(ids);

    return list;

}

示例:

 

2、list的类型

UserMapper.java

List<User> findUser_list(List<Integer>list)throws Exception;

UserMapper.xml

<!--list类型-->

    <select id="findUser_list" resultType="com.xiaomin.page.pojo.User">

    select * from sys_user

    <where>

        <foreach collection="list" item="user_id" open="and id in(" separator="," close=")">

            #{user_id}

        </foreach>

    </where>

  </select>

Controller.java

/**

 * list类型

 * @return

 * @throws Exception

 */

  @RequestMapping("/findUser_list")

  @ResponseBody

  public List<User> findUser_list()throws Exception{

    List<User> list = userMapper.findUser_list(Arrays.asList(new Integer[]{1,2,3,6}));

    return list;

}

测试截图:

 

 

3、对象类型

UserMapper.java


List<User> findUser_obj(UserQueryVo vo)throws Exception;

UserMapper.xml

<!--对象类型-->

  <select id="findUser_obj" parameterType="com.xiaomin.page.pojo.vo.UserQueryVo" resultType="com.xiaomin.page.pojo.User">

    select * from sys_user

        <where>

            <if test="ids !=null">

                <foreach collection="ids" item="user_id" open="and id in (" separator="," close=")">

                    #{user_id}

                </foreach>

            </if>

        </where>

  </select>

Controller.java


/**

 * 对象类型

 * @return

 * @throws Exception

 */

  @RequestMapping("/findUser_obj")

  @ResponseBody

  public List<User> findUser_obj()throws Exception{

    List<Integer> ids = new ArrayList<>();

    ids.add(1);

    ids.add(2);

    ids.add(3);

    UserQueryVo queryVo = new UserQueryVo();

    queryVo.setIds(ids);

    List<User> list = userMapper.findUser_obj(null);

    return list;

}

测试截图:

 

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Mybatis中的foreach标签主要用于遍历传入的数组、List或其他不定长结构,并在SQL语句中构建IN条件。它有三种使用场景:Listarray和Map。使用foreach标签时,需要指定集合对象的别名(item),以及在迭代过程中每次迭代到的位置的指定名字(index)。 在使用foreach标签时,需要指定open、separator和close属性。open表示在迭代开始时的起始语句,separator表示在每次迭代之间的分隔符,close表示在迭代结束时的结束语句。 需要注意的是,在使用foreach标签进行拼接时,如果使用的是单引号,需要使用${item}来进行拼接,而不是使用#{item}。 总结起来,Mybatis中的foreach标签用于遍历集合对象,在SQL语句中构建IN条件,可以指定别名和位置名,以及在迭代开始、分隔和结束时的语句。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [Mybatis中使用foreach](https://blog.csdn.net/MK2832070704/article/details/127052321)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [Mybatisforeach的三种用法](https://blog.csdn.net/lin252552/article/details/82691994)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值