mybatis实现批量删除

批量删除主要需要注意接口处需要写上@Param()加上你自己定义的collection集合名称。实现批量删除主要分为三步骤

一、写接口

批量删除是一个数组,因此传入的参数是一个数组。但是之后使用的foreach标签里面的需要id识别,因此需要自己给这个数组加上一个名称。

//批量删除
    void deleteById(@Param("idsss") int[] ids);

在这里插入图片描述

二、写SQL语句

主要就是foreach中的四个值。两个括号一个。一个集合,一个集合里的值。

<!--    批量删除数据-->
    <delete id="deleteById">
        delete
        from tb_brand
        where id
        in
        <foreach collection="idsss" item="id" open="(" close=")">
            #{id}
        </foreach>

    </delete>

在这里插入图片描述

三、写测试用例。

public void testDeleteById() throws IOException {
        //1.获取sqlSessionFactort
        //①加载mybatis的核心配置文件,获取sqlSessionFatory对象,从官网复制,
        String resource = "mybatis-config.xml"; //直接复制配置文件路径,注意是mybatis的
        InputStream inputStream = Resources.getResourceAsStream(resource);
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);

        //2.
        //获取sqlSession对象,用它来执行sql
        SqlSession sqlSession = sqlSessionFactory.openSession(true);

        //3.
        BrandMapper mapper = sqlSession.getMapper(BrandMapper.class);

        //4.
        int[] ids = {7};

        mapper.deleteById(ids);

        //5.
        sqlSession.close();
    }

在这里插入图片描述

小结一下啊

这里只需要注意两个地方。
①foreach标签里面的collection需要一个识别id,需要你自己定义。
②既然它需要,那我们就在 void deleteById(@Param("idsss") int[] ids); 里面写上。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值