package com.ruoyi.demo.controller; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.ruoyi.common.core.controller.BaseController; import com.ruoyi.common.core.domain.AjaxResult; import com.ruoyi.demo.domain.TestDemo; import com.ruoyi.demo.service.ITestDemoService; import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; import lombok.RequiredArgsConstructor; import org.springframework.beans.factory.annotation.Autowired; 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 */ @Api(value = "测试批量方法", tags = {"测试批量方法"}) @RequiredArgsConstructor(onConstructor_ = @Autowired) @RestController @RequestMapping("/demo/batch") public class TestBatchController extends BaseController { private final ITestDemoService iTestDemoService; /** * 新增批量方法 可完美替代 saveBatch 秒级插入上万数据 (对mysql负荷较大) */ @ApiOperation(value = "新增批量方法") @PostMapping() // @DataSource(DataSourceType.SLAVE) public AjaxResult add() { List list = new ArrayList<>(); for (int i = 0; i < 10; i++) { TestDemo testDemo = new TestDemo(); if (i % 2 == 0) { list.add(testDemo.setId((long) i + 1).setTestKey("批量更新").setValue("批量更新")); } else { list.add(testDemo.setOrderNum(-1L).setTestKey("批量新增").setValue("测试新增")); } } return toAjax(iTestDemoService.saveAll(list) ? 1 : 0); } /** * 删除批量方法 */ @ApiOperation(value = "删除批量方法") @DeleteMapping() // @DataSource(DataSourceType.SLAVE) public AjaxResult remove() { return toAjax(iTestDemoService.remove(new LambdaQueryWrapper() .eq(TestDemo::getOrderNum, -1L)) ? 1 : 0); } }