mybatis <foreach>标签动态增删改查方式

目录
  • <foreach>标签动态增删改查
    • mybatis<foreach>
    • 实战
    • 有了建表以及插入,当然少不了删除和更新
  • mapper.xml中<foreach>标签使用
    • 适用场景

<foreach>标签动态增删改查

mybatis<foreach>

有的时候在项目中需要查询某个列表时,可能会在代码中进行嵌套循环再取值,其实mybatis提供了这么一个标签,可以在SQL中进行循环(是不是很酸爽)

先来了解一下foreach这个标签有哪些元素:

  • item:表示集合中每一个元素进行迭代时的别名
  • index:指定一个名字,用于表示在迭代过程中,每次迭代到的位置
  • open:表示该语句以什么开始
  • separator:表示在每次进行迭代之间以什么符号作为分隔符
  • close:表示以什么结束
  • collection:被循环的集合或者数组

注意:

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

  • 如果传入的是单参数且参数类型是一个List的时候,collection属性值为list
  • 如果传入的是单参数且参数类型是一个array数组的时候,collection的属性值为array
  • 如果传入的参数是多个的时候,我们就需要把它们封装成一个Map或者Object。

实战

话不多说,看代码,首先是mybatis的XML如何写,拿动态创建表为例子,什么是动态创建表,就是可以随便生成表名,字段是传入进来的集合数组,根据这个数组内容来创建字段

<update id="createTable" parameterType="java.util.HashMap">
        CREATE TABLE IF NOT EXISTS ed_temp_${tableName}(
        id VARCHAR(32) NOT NULL,
        log_id VARCHAR(32),
        state INT,
        message VARCHAR(255)
        <foreach collection="list" item="column" open="," separator="VARCHAR(255),"
                 close="VARCHAR(255), PRIMARY KEY (id)">
            ${column.name}
        </foreach>
        ) ENGINE = InnoDB DEFAULT CHARSET = utf8;
    </update>

这个<foreach>看出,我传入的叫一个list的集合,别名叫column,从,开始,因为上面message少个逗号,中间用VARCHAR(255),做分隔符,已什么为结束都定义好了。

看Mapper类

/**
     * 动态创建表
     */
    void createTable(HashMap<String , Object> map);

看实现

    /**
     * 创建表
     * @param templateId 模板id
     */
    private void createTable(String templateId){
        List<EdTemplateField> fields = edTemplateFieldMapper.findByTemplate(templateId);
        List<EdFieldColumns> columns = new ArrayList<>();
        HashMap<String,Object> map = new HashMap<>(16);
        map.put("tableName",templateId);
        for (EdTemplateField field : fields) {
            columns.add(edFieldColumnsMapper.findByField(field.getId()).get(0));
        }
        map.put("list",columns);
        edTemplateMapper.createTable(map);
    }

逻辑是这样的,通过传入的ID,去寻找所需要的值,再创建一个List和一个Map,将表名放进来,在将需要的数组放进来,调用mapper的方法,最后就能成功创建一张动态表

往这个动态表里插入数据的方式也用到了<foreach>,应该说不得不用,不然怎么插入,又不知道表名又没有实体类

XML

    <insert id="tableInsert" parameterType="java.util.HashMap">
        INSERT INTO ed_temp_${tableName}(
        id,log_id,state,message
        <foreach collection="columns" item="column" open="," separator="," >
            ${column.name}
        </foreach>
        )VALUES(
        <foreach collection="values" item="value" open="REPLACE(UUID(),'-','')," separator="," >
            #{value}
        </foreach>
        )
    </insert>

两个<foreach>标签,一个是字段,刚刚那个动态建表的字段,一个是值

mapper类

/**
     * 动态插入
     * @param map
     */
    void tableInsert(HashMap<String,Object> map);

实现方法

/**
     * 保存数据到临时表
     * @param templateId 模板id
     * @param list 数据集合
     * @param hearTitle 数据对应的字段
     */
    private void tableInsert(String templateId,List<String> list,List<String> hearTitle){
         List<EdFieldColumns> columns = new ArrayList<>();
        HashMap<String,Object> map = new HashMap<>(16);
        map.put("tableName",templateId);
        for (String s : hearTitle) {
            columns.add(edFieldColumnsMapper.findByTemplateIdAndName(s,templateId));
        }
        map.put("columns",columns);
        map.put("values",list);
        edTemplateMapper.tableInsert(map);
    }

说明

其余的类代码就不贴了,逻辑是这样的,创建一个放字段的集合和传入的map,集合的值必须要和字段对应的上,不然插错字段值那就很尴尬,所以必须要通过动态创建的字段和值的顺序是一样的,比如第一个创建了name那插入的第一个就是name,这个意思,所以这里是根据顺序,先排好了字段,放入map里,再将要放入动态表的值放进来,进行mapper操作

有了建表以及插入,当然少不了删除和更新

删除表的xml

<update id="deleteTable" parameterType="java.lang.String">
    DROP TABLE ${tempTable}
</update>
<delete id="deleteTemporary">
        DELETE
        FROM
             ${tableName}
        WHERE
            id = #{id}
    </delete>

用于来删除不需要的表,以及删除数据

void deleteTable(@param(value = "tempTable") String tempTable);
void deleteTemporary(@Param("tableName") String tableName,
                         @Param("id") String id);

这是mapper接口的写法,传入要删除的表名就可以

更新的XML

<update id="updateTemporary">
        UPDATE ${tableName}
        SET
        <foreach collection="dataMap" index="key" item="value"  separator="," >
            ${key} = #{value}
        </foreach>
        WHERE
            id = #{id}
    </update>

对应的mapper接口

 void updateTemporary(@Param("tableName") String tableName,
                         @Param("id") String id,
                         @Param("dataMap") HashMap dataMap);

mapper.xml中<foreach>标签使用

循环参数内容,还具备在内容的前后添加内容,还具备添加分隔符功能。

适用场景

in  查询.批量新增中(mybatis 中 foreach 效率比较低)

1 如果希望批量新增,SQL 命令

insert into tableName VALUES (default,1,2,3),(default,4,5,6),(default,7,8,9)

2 openSession()必须指定底层 JDBC 的

PreparedStatement.addBatch();   
factory.openSession(ExecutorType.BATCH);

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。

(0)

相关推荐

  • MyBatis增删改查快速上手

    作为一个快乐的小码农,在每一个阶段往往都在重复写着不同版本的,学生管理,用户管理,注册登录,从 JavaSE 的控制台版,或者 GUI 版,再到 JavaWeb的 JSP版,再到纯粹使用 HTML 作为前端展示的版本,以及使用一个更新的技术,在此其中,我们用过 txt 做数据库,用 XML 也可以,到现在常用的 MySQL,增删改查一直是我们必不可少的一部分内容,即使你不懂原理,即使你对这个技术的理解不是很深刻,拿出你的增删改查,噼里啪啦就是一段乱敲,好歹还是能让你着手先做起来(当然,对技术的理

  • Mybatis实现动态增删改查功能的示例代码

    一.Mybatis 流程简介 最近在看 Mybatis 的源码,大致了解整个框架流程后便手写了一个特别简单的SimpMybatis的小Demo,来巩固这整个框架的学习.下图是我所画的框架大致执行流程:

  • Mybatis实现增删改查

    目录 一.mybatis的配置 1.1 添加相应的jar包 1.2 配置mybatis.xml文件 1.3 创建数据库 1.4 创建实体类 1.5 创建接口实现的方法 1.6 配置UserMapper.xml 文件 1.7 创建MybatisUtils的方法 二.Mybatis的增删改查 2.1 添加 2.2 修改 2.3 查询 2.4 删除 Mybatis实现增删改查 一.mybatis的配置 1.1 添加相应的jar包 在lib文件夹下面添加mybatis的核心jar包以及依赖的jar包同在

  • Mybatis实现数据的增删改查实例(CRUD)

    什么是 MyBatis? MyBatis 是支持普通 SQL 查询,存储过程和高级映射的优秀持久层框架. MyBatis 消除了几乎所有的 JDBC 代码和参数的手工设置以及对结果集的检索.MyBatis 可以使用简单的XML 或注解用于配置和原始映射,将接口和 Java 的 POJO(Plain Old Java Objects,普通的Java对象)映射成数据库中的记录. MyBatis下载:https://github.com/mybatis/mybatis-3/releases Mybat

  • mybatis <foreach>标签动态增删改查方式

    目录 <foreach>标签动态增删改查 mybatis<foreach> 实战 有了建表以及插入,当然少不了删除和更新 mapper.xml中<foreach>标签使用 适用场景 <foreach>标签动态增删改查 mybatis<foreach> 有的时候在项目中需要查询某个列表时,可能会在代码中进行嵌套循环再取值,其实mybatis提供了这么一个标签,可以在SQL中进行循环(是不是很酸爽) 先来了解一下foreach这个标签有哪些元素: i

  • mybatis使用xml进行增删改查代码解析

    MyBatis是支持普通sql查询.存储过程和高级映射的持久层框架. MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的检索封装. MyBatis可以使用 简单的XML或注解用于配置和原始映射,将接口和Java的POJO(Plain Old Java Objects 普通的Java对象)映射成数据库中的记录. 每一个Mybatis应用程序都以一个sqlSessionFactory对象的实例为核心. sqlSessionFactory对象的实例可以通过sqlSessionFa

  • Mybatis 条件查询 批量增删改查功能

    模糊查询: @Select({ "SELECT * FROM account where account like CONCAT('%',#{query},'%') or email like CONCAT('%',#{query},'%')" }) Account findAccountByAccountOrMail(@Param("query") String query); 批量添加: @Insert({ "<script>"

  • SpringBoot整合Mybatis与thymleft实现增删改查功能详解

    首先我们先创建项目 注意:创建SpringBoot项目时一定要联网不然会报错 项目创建好后我们首先对 application.yml 进行编译 #指定端口号server: port: 8888#配置mysql数据源spring:  datasource:    driver-class-name: com.mysql.cj.jdbc.Driver    url: jdbc:mysql://localhost:3306/nba?serverTimezone=Asia/Shanghai    use

  • MyBatis中SqlSession实现增删改查案例

    前言 开博客这是第一次写系列文章,从内心上讲是有点担心自己写不好,写不全,毕竟是作为java/mybatis学习的过程想把学习的路线和遇到的问题都总结下来,也让知识点在脑海里能形成一个体系. 开发环境 idea2016.mybatis3.SQLServer2012 pom.xml.mybatis.xml.log4j.properties 先贴上pom.xml是因为他直接和搭建开发环境和测试环境有关系,mybatis.xml则是连接数据库,log4j.properties在学习阶段配置上有助于我们

  • JavaWeb 使用DBUtils实现增删改查方式

    目录 JavaWeb 使用DBUtils实现增删改查 1.创建C3p0Utils类 2.创建DBUtilsDao类 3.创建测试类 4.执行测试类 Java DBUtils技术访问数据库 DBUtils 介绍 对数据库的查询语句的代码 JavaWeb 使用DBUtils实现增删改查 1.创建C3p0Utils类 创建cn.itcast.jdbc.utils包 代码如下: package cn.itcast.jdbc.utils; import javax.sql.DataSource; impo

  • 基于jQuery的动态增删改查表格信息,可左键/右键提示(原创自Zjmainstay)

    在线演示: http://demo.jb51.net/js/2012/jqueryAutoAddDeleteTableTr/jqueryAutoAddDeleteTableTr_leftClick.html//左键  复制代码 代码如下: <html> <head> <title>jQuery 动态增删表格</title> <meta http-equiv="Content-Type" content="text/html

  • spring boot2结合mybatis增删改查的实现

    1. 场景描述 本节结合springboot2.springmvc.mybatis.swagger2等,搭建一个完整的增删改查项目,希望通过这个基础项目,能帮忙朋友快速上手springboot2项目. 2. 解决方案 2.1新建springboot项目 使用idea新建springboot项目(springboot项目快速搭建) (1)new project (2)gav设置 2.2 项目整体图及说明2.2.1 整体图 2.2.2 说明 项目包含4大内容 (1)pom.xml maven项目必备

随机推荐