@Delete通过批量删除的方法

文章讲述了在MyBatis中使用@Delete注解进行批量删除操作时,遇到的List参数绑定问题。解决方案是修改SQL语句,利用<foreach>标签处理List参数,确保每个ID都能对应一个问号占位符,从而避免SQL语法错误。通过这样做,可以正确实现批量删除功能。
摘要由CSDN通过智能技术生成

由于MyBatis中@Delete注解在SQL中的语法是通过占位符的方式支持参数绑定,所以在使用#{}传入List类型参数时会默认生成一个单一的问号(?)占位符来代替这个List。但是这里我们要传递的是一个List内的多个ID值,所以当我们执行deleteByIdList方法时,MyBatis会将List作为一个参数处理,并尝试将其绑定到这个单独的占位符上,导致SQL语法错误。因此,为了正确地使用@Delete注解传递List类型参数,需要进行以下两步操作:

1:修改SQL语句,让它匹配List作为参数

@Mapper
public interface OssFileMapper {

    @Delete("<script>" + 
            "DELETE FROM oss_file WHERE id IN " +
            "<foreach item='id' collection='idList' separator=',' open='(' close=')'>" +
                "#{id}" +
            "</foreach>"+
            "</script>")
    void deleteByIdList(List<Long> idList);

}

2:使用

这样就可以正确地使用@Delete注解传递List类型参数进行批量删除操作了。

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值