当前位置: 首页 > news >正文

Mybatis批量操作

1、批量插入

 <!--批量操作-插入-->
    <!-- 相当于
    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>

测试

 @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、批量删除

<!--批量操作-删除-->
<!--相当于
 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>

测试:

@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();
        }
    }

相关文章:

  • 前端知识点---原型-原型链(javascript)
  • 【鸿蒙开发】Hi3861学习笔记-Visual Studio Code安装(New)
  • matlab 模糊pid实现温度控制
  • Java 常用工具类大全:高频工具类及代码示例(后续继续补充)
  • 大模型最新面试题系列:微调篇之微调基础知识
  • 使用 Elasticsearch 构建多模式 RAG 系统:哥谭市的故事
  • 【SpringMVC】常用注解:@MatrixVariable
  • C 语言实战:打造字符串加密器及实验要点解析
  • leetcode 3305. 元音辅音字符串计数 I 中等
  • Ubuntu从源代码编译安装QT
  • Git 的基本概念和使用方式
  • 网络安全就业形势
  • AGI大模型(6):提示词模型进阶
  • 【软考-架构】11.3、设计模式-新
  • C#中SerialPort 的使用
  • LabVIEW VI Scripting随机数波形图自动生成
  • MySQL的一些八股文
  • 上位机数据可视化:Qt表格美化
  • VSTO(C#)Excel开发10:启动和卸载顺序 事件处理 监视变化
  • A SURVEY ON POST-TRAINING OF LARGE LANGUAGE MODELS——大型语言模型的训练后优化综述——第2部分
  • 为何选择上海?两家外企提到营商环境、人才资源……
  • 微软将裁员3%,减少管理层
  • 第78届戛纳电影节开幕,罗伯特·德尼罗领取终身成就奖
  • 白天气温超30℃的北京,晚间下起了冰雹
  • 今天北京白天气温超30℃,晚间为何下冰雹?
  • 飙升至熔断,巴基斯坦股市两大股指收盘涨逾9%