`
yangyongByJava
  • 浏览: 127237 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

mybatis循环遍历集合以及使用多个参数对象的sql配置

 
阅读更多

1、mybatis循环删除数据的sql

循环删除时,要求相应的Mapper方法传递的参数是一个集合(如List),在<delete>标签的参数中设置parameterType="java.util.List",书写sql语句时,使用<foreach>标签循环,其中collection表示Mapper中传递的参数名,item便是循环时压入栈顶的元素,open表示第一次加入的sql前缀,separator表示集合中每个元素之间的分隔符,colse表示循环结束时为sql语句添加的后缀。具体配置如下:

<delete id="deleteList" parameterType="java.util.List">

DELETE FROM CITY WHERE 1 = 1

<foreach collection="list" item="item" open="AND CITY_NO IN(" separator="," close=")">

#{item.cityNo}

</foreach>

</delete>

 

2、mybatis中Mapper方法传递多个参数对象

如果在Mapper中的方法中传递了多个参数对象,可以在service层进行封装(系统的流程为controller->service->mapper),将多个参数封装到map中,用key值进行区别,然后在mapper.xml中的配置如下:

<select id="findByPage" resultMap="listCityMap" parameterType="java.util.Map">

SELECT CITY_NO, CITY_NAME, PROVINCE_NO FROM CITY WHERE 1 = 1

<if test="city.cityNo != null and city.cityNo != '' ">

AND CITY_NO = #{city.cityNo}

</if>

<if test="city.cityName != null and city.cityName != ''">

AND CITY_NAME = #{city.cityName}

</if>

<if test="city.provinceNo != null and city.provinceNo != ''">

AND PROVINCE_NO = #{city.provinceNo}

</if>

LIMIT #{page.startRowNum}, #{page.pageSize}

</select>

其中在Mapper.xml的<select>标签的参数中设置parameterType="java.util.Map",在service方法中,有page和city2个形参,故在service的方法中进行如下处理:

public List<City> findByPage(SimplePage page, City city) {

Map<String, Object> paramMap = new HashMap<String, Object>();

paramMap.put("page", page);

paramMap.put("city", city);

return cityMapper.findByPage(paramMap);

}

分享到:
评论

相关推荐

    mybatis关联/级联以及动态sql

    7. `&lt;foreach&gt;`:用于循环遍历集合,生成对应的IN或NOT IN子句,非常适合处理批量操作。 在实际开发中,动态SQL能够帮助我们编写更加灵活的查询,避免硬编码SQL,提高代码的可读性和复用性。通过合理使用这些标签,...

    详解MyBatis直接执行SQL查询及数据批量插入

    批量插入的优点在于,它将多个插入操作合并为一个SQL语句,减少了网络传输和数据库解析SQL的时间,提高了效率。 总结起来,MyBatis提供了一种灵活的方式,允许开发者直接执行SQL查询和批量插入数据。在使用时,需要...

    mybatis的开发

    - **foreach**:循环遍历集合,用于 IN 子句等。 - **sql** 片段:复用 SQL 代码块,提高重用性和可读性。 综上所述,MyBatis 通过简化 JDBC 操作、提供灵活的 SQL 映射机制以及支持动态 SQL 等特性,极大地提高...

    MyBatis教程.rar

    例如,可以使用、、、等标签来实现条件判断,标签则用于循环遍历集合参数。 在执行SQL时,MyBatis通过参数映射将Java对象的属性值与SQL语句的参数对应起来,这使得我们能方便地执行插入、更新、删除和查询操作。...

    mybatis帮助文档-中文

    MyBatis可以使用简单的XML或注解进行配置和原始映射,将接口和Java的POJOs(Plain Old Java Objects,普通的Java对象)映射成数据库中的记录。 1. **MyBatis基本概念** - SQL映射框架:MyBatis的核心是SQL映射文件,...

    mybatis 3 中文 指南

    - **`foreach`**:用于循环遍历集合参数。 #### Java API 除了XML配置外,MyBatis还支持Java API,包括`SqlSessionFactoryBuilder`、`SqlSessionFactory`、`SqlSession`等,为开发者提供了灵活的选择。 #### 结构...

    mybatis-3.0.4源码

    MyBatis是一个优秀的Java持久层框架,它支持定制化SQL、存储过程以及高级映射。在3.0.4版本中,MyBatis提供了一系列关键功能,帮助开发者更高效地处理数据库操作。以下是对`mybatis-3.0.4源码`的详细解析。 一、...

    MyBatis3中文官方文档

    - **循环遍历**:用于遍历集合或数组,并将其值添加到SQL语句中。 #### 4.5 bind - **变量绑定**:用于绑定变量到SQL语句中。 ### 五、多数据库支持 - **多数据库支持**:MyBatis支持多种数据库系统,可以在配置...

    MyBatis3 中文版用户指南手册

    - **foreach**:用于循环遍历集合。 #### Java API 除了 XML 映射文件,MyBatis 还支持通过 Java API 进行配置和操作。这包括 `SqlSessionFactoryBuilder`、`SqlSessionFactory`、`SqlSession` 等核心类的使用。 ...

    mybatis Mapper.xml中传参多选 字符串形式逗号分隔 AND中拼接OR.rar

    在SQL语句中,我们可以使用`&lt;foreach&gt;`标签来遍历集合中的元素,生成`OR`子句。下面是一个示例: ```xml SELECT * FROM your_table WHERE != null and tags.size() &gt; 0"&gt; (" separator=" OR " close=")"&gt; ...

    尚硅谷Mybatis视频教程41-50

    - **Foreach**:Mybatis中的Foreach标签用于循环遍历集合并生成SQL语句中的IN或JOIN子句,这里是针对MySQL环境下的批量插入。 - **两种批量插入方式**:一种是通过拼接SQL语句的方式,另一种可能是利用存储过程...

    学习手册 “玩转”Java系列 — Mybatis

    - `foreach`标签用于遍历集合,生成动态in语句或其他循环结构的SQL。 9. **缓存机制** - Mybatis提供了一级缓存(SqlSession级别)和二级缓存(Mapper级别),提高查询效率。 - 可以自定义缓存实现,控制缓存...

    mybatis动态sql及关联查询项目示例

    `&lt;foreach&gt;`标签则常用于循环遍历集合,生成IN或NOT IN类型的SQL条件。 关联查询是数据库操作中常见的需求,尤其在处理一对多或多对一关系时。在MyBatis中,可以通过`&lt;association&gt;`和`&lt;collection&gt;`标签进行配置,...

    mybatis-3.5.4.pdf

    - **foreach**:循环遍历集合中的元素。 ### Java API #### 6.1 Java API 使用指南 除了通过XML配置外,MyBatis还支持通过Java API来进行操作。主要涉及以下几个方面: - **SqlSessionFactory**:用于创建...

    mybatis笔记

    - ****:循环遍历集合。 #### 示例代码 - **&lt;if&gt; 示例**: ```xml SELECT * FROM user WHERE 1=1 != null"&gt; AND userId = #{userId} ``` - **&lt;choose&gt; 示例**: ```xml UPDATE user != null...

    mybatis第二天课堂笔记

    - **foreach**:用于循环遍历集合或数组。 - **sql 片段**:定义可重用的 SQL 代码块。 #### 五、高级映射 - **一对一映射**:可以使用 `&lt;association&gt;` 标签来处理。 - **一对多映射**:使用 `&lt;collection&gt;` 标签...

    ORM框架-Mybatis(二)(7)

    例如,`&lt;if&gt;`、`&lt;choose&gt;`、`&lt;when&gt;`、`&lt;otherwise&gt;`标签用于实现条件语句,`&lt;foreach&gt;`用于遍历集合并生成嵌套的SQL片段。 **五、级联操作(Cascade)** 提到"mybatis-demo-cascade",可能涉及的是Mybatis的级联...

    MyBatis中文教程

    - **foreach**:循环遍历集合,常用于IN语句。 #### 八、Java API - **SqlSession**:提供了一系列方法用于执行SQL语句、管理事务等。 - **SqlSessionFactoryBuilder**:用于构建SqlSessionFactory。 - **...

Global site tag (gtag.js) - Google Analytics