mybatis批处理mysql_Mybatis插入/删除批处理

在操作数据库时,经常会碰到批量插入、批量删除的情况,直接执行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 testList);

XML代码

...

INSERT IGNORE INTO

test_table(test_x, test_y, test_z)

VALUES

#{item}.x, #{item.y}, #{item}.z

INSERT INTO

test_table(test_x, test_y, test_z)

VALUES

#{item}.x, #{item.y}, #{item}.z

ON DUPLICATE KEY UPDATE

test_x = VALUES(test_x),

test_y = VALUES(test_y),

test_z = VALUES(test_z)

...

批量插入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 testList);

XML代码

...

DELETE FROM

test_table

WHERE

test_x = #{item.x} AND test_y = #{item.y} AND test_z = #{item.z}

...

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。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL提供了多种方式进行批量插入数据。根据引用\[1\]中的测试结果,以下是几种常用的批量插入方式: 1. 使用for循环单条插入:通过循环遍历数据集合,逐条执行插入语句。这种方式简单直接,但是每次插入都需要编译一次SQL语句,效率较低。 2. 拼接SQL语句:将多条插入语句拼接成一个较长的SQL语句,然后一次性执行。这种方式减少了SQL语句的编译次数,提高了效率。 3. 使用批量插入函数saveBatch():MySQL的ORM框架通常提供了批量插入函数,如MyBatis的saveBatch()方法。该方法可以将数据集合直接传入,框架会自动进行批量插入操作,效率较高。 4. 循环 + 开启批处理模式:在循环中执行插入语句,并在循环开始前开启MySQL批处理模式。这种方式可以减少网络通信次数,提高效率。 根据引用\[2\]中的问题描述,如果遇到无法成功插入数据的情况,可以尝试使用以上的批量插入方式来解决。另外,引用\[3\]中的示例展示了常规插入一条数据的SQL语句格式。 总结来说,根据具体情况选择合适的批量插入方式可以提高MySQL插入效率。 #### 引用[.reference_title] - *1* [MySQL优化:批量插入大数据4种实用、讲究方案的测试](https://blog.csdn.net/a18505947362/article/details/123667215)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [MySQL insert into 批量插入大量数据 报错](https://blog.csdn.net/qq_14959289/article/details/126619787)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [mysql批量更新,批量插入之replace语句/insert into... on duplicate key update语句](https://blog.csdn.net/qq_41633199/article/details/115768210)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值