Mybatis批处理
批量插入数据
<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},
#{currentPrice},#{discount},#{isFreeDelivery},#{categoryId})
</foreach>
</insert>
@Test
public void testBatchInsert(){
SqlSession sqlSession=null;
try{
sqlSession=MyBatisUtils.openSession();
List<Goods> list=new ArrayList();
for(int i=0;i<10000;i++){
Goods goods = new Goods();
goods.setTitle("");
//goods.set...();
goods.setCategoryId(43);
list.add(goods);
}
sqlSession.insert("goods.batchInsert",list);
sqlSession.commit();
}catch (Exception e){
if(sqlSession!=null){
sqlSession.rollback();
}
throw e;
}finally {
MyBatisUtils.closeSession(sqlSession);
}
}
批量插入数据的局限:
1.无法获得插入数据的id 2.批量生成的SQL太长,可能会被服务器拒绝
批量删除
<delete id="batchDelete" parameterType="java.util.List">
delete t_goods where goods_id in
<foreach collection="list" item="item" index="index" open="(" close=")" separator=",">
#{item}
</foreach>
</delete>
@Test
public void testBatchDelete(){
SqlSession sqlSession=null;
try{
sqlSession=MyBatisUtils.openSession();
List list=new ArrayList();
list.add(1920);
list.add(1921);
list.add(1922);
sqlSession.delete("goods.batchDelete", list);
sqlSession.commit();
}catch (Exception e){
if(sqlSession!=null){
sqlSession.rollback();
}
throw e;
}finally {
MyBatisUtils.closeSession(sqlSession);
}
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 一起来玩mcp_server_sqlite,让AI帮你做增删改查!!