zoukankan      html  css  js  c++  java
  • Mybatis中使用集合、数组

    一、简述

      本文讲Mybatis中如何将传入参数为数组或者集合对象,进行遍历,组合Where条件中如in条件等内容。

      有3种情况:
        如果传入的是单参数且参数类型是一个List的时候,collection属性值为list .或者使用传入参数中@param定义的参数名称。
        如果传入的是单参数且参数类型是一个array数组的时候,collection的属性值为array .或者使用传入参数中@param定义的参数名称。
        如果传入的参数是多个的时候,我们就需要把它们封装成一个Map了,当然单参数也可以封装成map,实际上如果你在传入参数的时候,在MyBatis里面也是会把它封装成一个Map的,map的key就是参数名,所以这个时候collection属性值就是传入的List或array对象在自己封装的map里面的key.

    二、例子

        <!--List:forech中的collection属性类型是List,collection的值必须是:list,item的值可以随意,Dao接口中参数名字随意 -->
        <select id="getEmployeesListParams" resultType="Employees">
            select *
            from EMPLOYEES e
            where e.EMPLOYEE_ID in
            <foreach collection="list" item="employeeId" index="index"
                open="(" close=")" separator=",">
                #{employeeId}
            </foreach>
        </select>
    
        <!--Array:forech中的collection属性类型是array,collection的值必须是:list,item的值可以随意,Dao接口中参数名字随意 -->
        <select id="getEmployeesArrayParams" resultType="Employees">
            select *
            from EMPLOYEES e
            where e.EMPLOYEE_ID in
            <foreach collection="array" item="employeeId" index="index"
                open="(" close=")" separator=",">
                #{employeeId}
            </foreach>
        </select>
    
        <!--Map:不单单forech中的collection属性是map.key,其它所有属性都是map.key,比如下面的departmentId -->
        <select id="getEmployeesMapParams" resultType="Employees">
            select *
            from EMPLOYEES e
            <where>
                <if test="departmentId!=null and departmentId!=''">
                    e.DEPARTMENT_ID=#{departmentId}
                </if>
                <if test="employeeIdsArray!=null and employeeIdsArray.length!=0">
                    AND e.EMPLOYEE_ID in
                    <foreach collection="employeeIdsArray" item="employeeId"
                        index="index" open="(" close=")" separator=",">
                        #{employeeId}
                    </foreach>
                </if>
            </where>
        </select>
    
    Mapper类:
    public interface EmployeesMapper { 
    
        List<Employees> getEmployeesListParams(List<String> employeeIds);
    
        List<Employees> getEmployeesArrayParams(String[] employeeIds);
    
        List<Employees> getEmployeesMapParams(Map<String,Object> params);
    }
    
    
    
    根据数组批量查询
    List<Privilege> selectPrivilegeByIds(@Param("privilegeIds") Integer[] privilegeIds);
    
    <select id="selectPrivilegeByIds" resultMap="BaseResultMap" >
     select 
      <include refid="Base_Column_List" />
      from diary_privilege
     where id in
      <foreach collection="array" item="item" index="index" open="(" separator="," close=")">
                  #{item}
       </foreach>
    </select>
    根据集合插入批量插入
    
    int insertEmployeeRole(EmployeeRoleVo employeeRole);(EmployeeRoleVo中包含List<Role> roleList)
     
      <insert id="insertEmployeeRole" parameterType="com.jimmy.demo.vo.EmployeeRoleVo" >
      insert into diary_employee_role (employeeId,roleId)
      values
      <foreach collection="roleList" item="item" index="index" separator="," >  
          (#{employee.eid},#{item.id})  
      </foreach>  
    </insert>

      本文例子参考自:https://www.cnblogs.com/jimmy-muyuan/p/5467252.html 非常感谢原作者煮海焚天分享。

  • 相关阅读:
    FastDFS集群安装说明
    关于Sentaurus的日常(一)(Basics)
    关于Sentaurus的日常(三)
    记录程序运行时间之clock 函数
    Mysql 使用经验 2013
    proxy ip 收集方式总结
    操作系统的默认格式的陷阱
    VNC server 使用手记
    div body 间距
    asp.net处女作
  • 原文地址:https://www.cnblogs.com/songxingzhu/p/10457347.html
Copyright © 2011-2022 走看看