Mybatis插入/删除批处理

文章作者:Tyan
博客:noahsnail.com  |  CSDN  |  简书

在操作数据库时,经常会碰到批量插入、批量删除的情况,直接执行SQL语句还好做一点,当使用Mybatis进行批量插入、批量删除时会有一些问题。下面对使用Mybatis批量插入,批量删除进行介绍。

1. 批量插入

  • Java代码:
// Model: Test.java

@Data
public class Test {
    private String x;
    private String y;
    private String z;
}

// Mapper: TestMapper.java
public void insertTestList(List<Test> testList);
  • XML代码
<!-- XML: TestMapper.XML -->

...

<!-- 忽略重复数据 -->
<insert id="insertTestList" parameterType="Test">
    INSERT IGNORE INTO 
        test_table(test_x, test_y, test_z)
    VALUES
    <foreach item="item" index="index" collection="list" open="(" close=")" separator=",">
        #{item}.x, #{item.y}, #{item}.z
    </foreach>
</insert>

<!-- 更新重复数据 -->
<insert id="insertTestList" parameterType="Test">
    INSERT INTO 
        test_table(test_x, test_y, test_z)
    VALUES
    <foreach item="item" index="index" collection="list" open="(" close=")" separator=",">
        #{item}.x, #{item.y}, #{item}.z
    </foreach>
    ON DUPLICATE KEY UPDATE
        test_x = VALUES(test_x),
        test_y = VALUES(test_y),
        test_z = VALUES(test_z)
</insert>

...
  • 批量插入SQL语句
insert into test_table(x, y, z) values (1, 1, 1), (2, 2, 2), (3, 3, 3)

备注:VALUE()是Mysql的一个函数,具体解释可以查看文档function_values

主要功能就是在数据重复时可以获取要更新的值。

2. 批量删除

  • Java代码:
// Model: Test.java

@Data
public class Test {
    private String x;
    private String y;
    private String z;
}

// Mapper: TestMapper.java
public void deleteTestList(List<Test> testList);
  • XML代码
<!-- XML: TestMapper.XML -->

...

<delete id="deleteTestList" parameterType="Test">
    DELETE FROM 
        test_table
    WHERE
    <foreach item="item" index="index" collection="list" open="(" close=")" separator="OR">
        test_x = #{item.x} AND test_y = #{item.y} AND test_z = #{item.z}
    </foreach>
</delete>

...
  • SQL语句
delete from test_table where (test_x = 1 AND test_y = 1 AND test_z = 1) or (test_x = 2 AND test_y = 2 AND test_z = 2) or (test_x = 3 AND test_y = 3 AND test_z = 3)

备注:上面的代码为x,y,z为联合主键的情况,普通情况使用where id in

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1. 简介 1.1 什么是 MyBatis ? MyBatis 是支持定制化 SQL、存储过程以及高级映射的优秀的...
    笨鸟慢飞阅读 5,708评论 0 4
  • Spark SQL, DataFrames and Datasets Guide Overview SQL Dat...
    草里有只羊阅读 18,399评论 0 85
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,785评论 18 399
  • Spring 技术笔记Day 1 预热知识一、 基本术语Blob类型,二进制对象Object Graph:对象图...
    OchardBird阅读 1,011评论 0 2
  • 假期的到来,总是让我和黄澄雀跃的像个兔子,积蓄了一学期的金钱和精力终于是有了时间可以得到施展。“去三亚吧,走了那么...
    比利德阅读 367评论 2 1