mybatis批量删除mapper

本文介绍了如何使用Mybatis进行批量删除操作,具体实现了根据完税证号码删除记录的功能。通过将完税证号码分割存储到list中,调用Mapper接口的delete方法,利用foreach标签动态构建SQL语句。Mapper配置中展示了删除方法的详细XML映射,包括条件判断和in语句的使用。此外,还总结了Mybatis中不同参数类型的传值方式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


使用mybatis的删除前台选定的几条数据;删除一条数据;删除所有数据。


我是使用了list来传值,因为我的需求是通过完税证号码删除记录。

mapper里边使用foreach标签
 
java代码:
    String[] split = wszhm.split(",");
       List list = new ArrayList();
       for(int i=0;i<split.length;i++){
           list.add(split[i]);
       }
    delete = this.getSqlSessionTemplate().delete(HgjksDelServiceHandler.class.getName()+".delHgjkss", list);


以下是mapper里边的:
<!--  删除 -->
<delete id="delHgjkss" parameterType = "java.util.List">
     delete from jh_hgjksdr where 1=1
     <if test="wszhm !=null and wszhm != ''">
     and wszhm in
      <foreach collection="list"  index="index" item="item" open="(" separator="," close=")"  >
       #{item}
      </foreach>
     </if>
</delete>


一般传值主要有三种:
 1.     如果传入的是单参数且参数类型是一个List的时候,collection属性值为list

2.     如果传入的是单参数且参数类型是一个array数组的时候,collection的属性值为array

3.     如果传入的参数是多个的时候,我们就需要把它们封装成一个Map了,当然单参数也可以封装成map,
实际上如果你在传入参数的时候,在breast里面也是会把它封装成一个Map的,map的key就是参数名,
所以这个时候collection属性值就是传入的List或array对象在自己封装的map里面的key
http://blog.sina.com.cn/s/blog_6a0cd5e501011snl.html
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值