Mybatis批量操作

1、批量插入

xml 复制代码
 <!--批量操作-插入-->
    <!-- 相当于
    INSERT INTO t_goods (c1,c2,c3) VALUES (a1,a2,a3),(b1,b2,b3),(d1,d2,d3),...
    -->
    <insert id="batchInsert" parameterType="java.util.List">
        INSERT INTO t_goods (title,sub_title,original_cost,current_price,discount,is_free_delivery,category_id) VALUES
          <foreach collection="list" item="item" index="index" separator=",">
              (#{item.title},#{item.subTitle},#{item.originalCost},#{item.currentPrice},#{item.discount},#{item.isFreeDelivery},#{item.categoryId})
          </foreach>
    </insert>

测试

java 复制代码
 @Test
    public void batchInsertTest(){
        SqlSession sqlSession = null;
        try {
            sqlSession = MyBatisUtil.getSqlSession();
            PageHelper.startPage(1, 6);
            GoodsMapper mapper = sqlSession.getMapper(GoodsMapper.class);
            List<Goods> goodsList = new ArrayList<Goods>();
            for (int i = 0; i < 10; i++) {
                Goods goods = new Goods();
                goods.setTitle("测试产品"+i);
                goods.setSubTitle("测试产品副标题"+i);
                goods.setDiscount(0.88f);
                goods.setIsFreeDelivery(1);
                goods.setOriginalCost(155f);
                goods.setCategoryId(40);
                goods.setCurrentPrice(888f);
                goodsList.add(goods);
            }
            int insert = mapper.batchInsert(goodsList);
            if (insert == goodsList.size()) {
                sqlSession.commit();
                System.out.println("插入数据成功");
            }else{
                System.out.println("插入数据失败");
                sqlSession.rollback();
            }

        } catch (Exception e) {
            System.out.println("插入数据失败");
            sqlSession.rollback();
            throw new RuntimeException(e);
        } finally {
            sqlSession.close();
        }
    }

1、批量插入数据无法获得插入数据的id,若后续需要使用该id继续操作,需要想别的办法
2、若批量插入的数据太多,生成的批量插入SQL过长,可能会被服务器拒绝,可以改为分成几次来完成

2、批量删除

xml 复制代码
<!--批量操作-删除-->
<!--相当于
 DELETE FROM t_goods WHERE goods_id IN (a1,a2,a3,a4,a5...)
-->
<delete id="batchDelete" parameterType="java.util.List">
    DELETE FROM t_goods WHERE goods_id IN
    <foreach collection="list" item="item" index="index" separator=","  open="(" close=")">
        #{item}
    </foreach>
</delete>

测试:

java 复制代码
@Test
    public void batchDeleteTest(){
        SqlSession sqlSession = null;
        try {
            sqlSession=MyBatisUtil.getSqlSession();
            GoodsMapper mapper = sqlSession.getMapper(GoodsMapper.class);
            List<Integer> parameterList = Arrays.asList(2600, 2601,2602);
            int delete = mapper.batchDelete(parameterList);
            if (delete == parameterList.size()) {
                System.out.println("删除数据成功");
                sqlSession.commit();
            }else{
                System.out.println("删除数据失败");
                sqlSession.rollback();
            }
        } catch (Exception e) {
            System.out.println("删除数据失败");
            sqlSession.rollback();
            throw new RuntimeException(e);
        } finally {
            sqlSession.close();
        }
    }
相关推荐
敲代码的嘎仔27 分钟前
Java后端面试——SSM框架面试题
java·面试·职场和发展·mybatis·ssm·springboot·八股
ruanyongjing1 小时前
SpringBoot3 整合 Mybatis 完整版
mybatis
小江的记录本4 小时前
【MyBatis-Plus】Spring Boot + MyBatis-Plus 进行各种数据库操作(附完整 CRUD 项目代码示例)
java·前端·数据库·spring boot·后端·sql·mybatis
小江的记录本7 小时前
【MyBatis-Plus】MyBatis-Plus的核心特性、条件构造器、分页插件、乐观锁插件
java·前端·spring boot·后端·sql·tomcat·mybatis
码界奇点9 小时前
基于Spring Boot和MyBatis的图书管理系统设计与实现
spring boot·后端·车载系统·毕业设计·mybatis·源代码管理
Javatutouhouduan10 小时前
SpringBoot如何快速精通?
java·spring boot·mybatis·java面试·后端开发·java编程·java程序员
稻草猫.13 小时前
MyBatis进阶:动态SQL与MyBatis Generator插件使用
java·数据库·后端·spring·mvc·mybatis
小王不爱笑1321 天前
MyBatis 执行流程源码级深度解析:从 Mapper 接口到 SQL 执行的全链路逻辑
数据库·sql·mybatis
弹简特1 天前
【JavaEE18-后端部分】 MyBatis 入门第二篇:使用注解完成增删改查(含有参数传递底层原理)
spring boot·mybatis
小王不爱笑1321 天前
SpringBoot 自动装配深度解析:从底层原理到自定义 starter 实战(含源码断点调试)
java·spring boot·mybatis