package com.dl.demo.controller; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.dl.common.core.controller.BaseController; import com.dl.common.core.domain.R; import com.dl.demo.domain.TestDemo; import com.dl.demo.mapper.TestDemoMapper; import lombok.RequiredArgsConstructor; import org.springframework.web.bind.annotation.DeleteMapping; import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; import java.util.ArrayList; import java.util.List; /** * 测试批量方法 * * @author Lion Li * @date 2021-05-30 */ @RequiredArgsConstructor @RestController @RequestMapping("/demo/batch") public class TestBatchController extends BaseController { /** * 为了便于测试 直接引入mapper */ private final TestDemoMapper testDemoMapper; /** * 新增批量方法 可完美替代 saveBatch 秒级插入上万数据 (对mysql负荷较大) *

* 3.5.0 版本 增加 rewriteBatchedStatements=true 批处理参数 使 MP 原生批处理可以达到同样的速度 */ @PostMapping("/add") // @DS("slave") public R add() { List list = new ArrayList<>(); for (int i = 0; i < 1000; i++) { TestDemo testDemo = new TestDemo(); testDemo.setOrderNum(-1); testDemo.setTestKey("批量新增"); testDemo.setValue("测试新增"); list.add(testDemo); } return toAjax(testDemoMapper.insertBatch(list)); } /** * 新增或更新 可完美替代 saveOrUpdateBatch 高性能 *

* 3.5.0 版本 增加 rewriteBatchedStatements=true 批处理参数 使 MP 原生批处理可以达到同样的速度 */ @PostMapping("/addOrUpdate") // @DS("slave") public R addOrUpdate() { List list = new ArrayList<>(); for (int i = 0; i < 1000; i++) { TestDemo testDemo = new TestDemo(); testDemo.setOrderNum(-1); testDemo.setTestKey("批量新增"); testDemo.setValue("测试新增"); list.add(testDemo); } testDemoMapper.insertBatch(list); for (int i = 0; i < list.size(); i++) { TestDemo testDemo = list.get(i); testDemo.setTestKey("批量新增或修改"); testDemo.setValue("批量新增或修改"); if (i % 2 == 0) { testDemo.setId(null); } } return toAjax(testDemoMapper.insertOrUpdateBatch(list)); } /** * 删除批量方法 */ @DeleteMapping() // @DS("slave") public R remove() { return toAjax(testDemoMapper.delete(new LambdaQueryWrapper() .eq(TestDemo::getOrderNum, -1L))); } }