`
一头老牛
  • 浏览: 9846 次
  • 性别: Icon_minigender_1
  • 来自: 贵阳
社区版块
存档分类
最新评论

mybatis 传参是list ,array, map

 
阅读更多

<!--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>

分享到:
评论

相关推荐

    MyBatis传入集合 list 数组 map参数的写法

    在MyBatis中,处理集合参数如list、array以及map是非常常见的操作。这些参数通常用于构建动态SQL,特别是当需要在`IN`语句中使用多个值时。下面将详细解释如何在MyBatis中使用这些参数类型。 1. **List参数**: 当...

    Mybatis框架 mapper.xml文件中parameterType传递参数常用的几种方式.pdf

    以下是几种常用的parameterType参数传递方式以及#和$在Mybatis中传参的区别。 1. 使用依次顺序传参: 在这种方式中,参数按照顺序传递,SQL语句中使用#{参数索引}来引用参数。例如,有一个查询用户的方法,用户名...

    测试mybatis里foreach用法

    在MyBatis中,`&lt;foreach&gt;`标签是一个非常重要的元素,它主要用于动态SQL语句的构建,尤其是在处理集合数据类型如List、Array、Map时。`&lt;foreach&gt;`标签的使用可以极大地提高代码的可读性和可维护性,避免了传统的字符...

    springmybatis

    MyBatis 目录(?)[-] mybatis实战教程mybatis in action之一开发环境搭建 mybatis实战教程mybatis in action之二以接口的方式编程 mybatis实战教程mybatis in action之三实现数据的增删改查 mybatis实战教程mybatis ...

    Java调用存储过程--传入集合参数

    p_peopleArray IN people_Oracle_LIST, p_ID IN number, p_out OUT VARCHAR2 ) AS ``` #### 四、综合实践案例 为了更直观地理解整个流程,我们可以考虑一个具体的场景,例如更新数据库中的一批用户信息。在这个...

    关于 MyBatis 我总结了 10 种通用的写法.docx

    如果传入的参数是多个,那么需要将它们封装成一个Map,然后collection属性值就是传入的List或array对象在自己封装的map里面的key。 4. choose标签的使用 choose标签是MyBatis中一个非常有用的标签,用于按顺序将...

    Mybatis 传输List的实现代码

    在处理复杂数据传输时,MyBatis 提供了处理 List 和 Array 类型参数的方法。本文将详细讲解如何在 MyBatis 中实现通过 List 或 Array 传递参数来执行查询操作。 首先,当查询的参数只有一个,如一个 List&lt;Long&gt; 或 ...

    MyBatis中Foreach参数问题.doc

    当传入一个集合类型的参数时,MyBatis会将其封装成一个包含`collection`和`list`两个键的Map对象。具体实现如下: ```java private Object wrapCollection(Object object) { DefaultSqlSession.StrictMap map; if...

    mybatis常用语句和lyaui 多条件查询加分页

    作为入参时,`List`对象默认使用`list`作为键,数组对象使用`array`作为键,Map对象需要自定义键。 ##### 3. 修改用户 - **接口定义**: ```java /** * 修改用户根据userId */ public int updateUsersById(Users...

    MyBatis 深入浅出-动态SQL

    &lt;foreach item="item" index="index" collection="array" open="(" separator="," close=")"&gt; #{item} ``` - **当传入参数是多个时,需要将它们封装成一个Map**: ```xml ...

    Mybatis分页插件 PageHelper5.0.0 使用

    public List&lt;Sys_user&gt; selectByPageCondition(Map, Object&gt; map) { int pageNo = Integer.parseInt(map.get("pageNo").toString()); int pageSize = Integer.parseInt(map.get("pageSize").toString()); ...

    MyBatis参数处理实现方法汇总

    集合(List、Set)或数组也会被封装到Map中,键名分别为`collection`、`list`或`array`。例如,`List&lt;Integer&gt; ids`,在SQL中可以通过`#{list[0]}`来获取第一个元素的值。 8. **参数值的获取**: - `#{}`:以预...

    MyBatis批量插入(insert)数据操作

    `foreach`标签是MyBatis提供的循环构造SQL语句的工具,它可以迭代任何集合类型的数据,包括List、Set等。`collection`属性的值取决于传入参数的类型,例如: - 如果是List,`collection`应为`list` - 如果是数组...

    mybatis中批量插入的两种方式(高效插入)

    - `collection`: 必须指定,用于确定集合来源,可能是`list`、`array` 或者在多参数情况下封装的`Map`。 - `open`: SQL语句的开始字符。 - `separator`: 每次迭代之间的分隔符。 - `close`: SQL语句的结束字符。 ...

    MyBatis动态标签.pdf

    - 如果传入的是单参数且参数类型是一个`Array`,则默认使用`array`作为`Array`对象的键。 - 如果传入的参数是多个,可以封装到一个`Map`中,但是`Map`对象没有默认的键,必须使用`@Param`注解指定`collection`的键。...

    详解mybatis foreach collection示例

    如果参数个数大于一个,则会被封装成Map,key值如果使用了Mybatis的Param注解,则会使用该key值,否则默认统一使用数据序号,从1开始。 在使用MyBatis foreach collection时,需要注意以下规则: 1. 当查询的参数...

    MyBatis的foreach语句详解

    MyBatis的`foreach`语句是其动态SQL功能中的一个重要组成部分,主要用于处理SQL语句中的循环和集合数据。在数据库操作中,特别是在构建`IN`条件时,`foreach`非常实用,它可以避免手动拼接SQL字符串,提高代码的...

    详解MyBatis 常用写法

    其中,collection传入的List或Array或自己封装的Map;item是集合中元素迭代时的别名;index是集合中元素迭代的索引;open是where后面表示以什么开始,如以‘('开始;separator是表示在每次进行迭代时的分隔符;...

    Mybatis数据批量插入如何实现

    3. 如果传入的参数是多个的时候,我们就需要把它们封装成一个Map了,当然单参数也可以封装成map。 测试示例 下面是一个简单的测试示例: ```java @Test public void insertUserBatch() { List&lt;User&gt; users = new...

Global site tag (gtag.js) - Google Analytics