MybatisPlus------BaseMapper<T>删除方法详解(三)

MybatisPlus------BaseMapper删除方法详解(三)

MybatisPlus框架中,创建的mapper接口,需要继承BaseMapper接口,T代表与表对应的实体类。
BaseMapper接口中提供了对单表进行增删改查的基础方法。
下面分别介绍四种:
int deleteById(T entity);
int deleteById(Serializable id);
int deleteByMap(@Param(Constants.COLUMN_MAP) Map<String, Object> columnMap);
int deleteBatchIds(@Param(Constants.COLL) Collection<?> idList);

第一种:int deleteById(T entity);

根据传入对象的id进行删除

//根据对象的id进行删除
        BaseProcedure baseProcedure = new BaseProcedure();
        baseProcedure.setId("a82f591dc76541ca98aaa4f8f7240c8d");
        int result = baseProcedureMapper.deleteById(baseProcedure);
        System.out.println("result:{}"+result);

第二种:int deleteById(Serializable id);

根据传入的字符串,作为id进行删除

        //根据id字段进行删除
        int resultById = baseProcedureMapper.deleteById("a82f591dc76541ca98aaa4f8f7240c8d");
        System.out.println("resultById:{}"+resultById);

第三种:int deleteByMap(@Param(Constants.COLUMN_MAP) Map<String, Object> columnMap);

根据map集合中所设置的条件删除用户信息。

        //根据map集合中所设置的条件删除用户信息
        Map<String,Object> stringObjectMap = new HashMap<>();
        stringObjectMap.put("name","张三");
        stringObjectMap.put("age",23);
        int resultByMap = baseProcedureMapper.deleteByMap(stringObjectMap);
        System.out.println("resultByMap:{}"+resultByMap);

注意此处传入的key为数据库表字段,如果传入的和表字段不符会报错。
在这里插入图片描述

第四种:int deleteBatchIds(@Param(Constants.COLL) Collection<?> idList);

根据传入的ID集合进行批量删除。

//批量删除,根据list中的id集合进行删除  通过id in (?,?,?)的方式
        List<String> list = new ArrayList<>();
        list.add("sda");
        list.add("ssss");
        list.add("sddd");
        int resultByIdList = baseProcedureMapper.deleteBatchIds(list);
        System.out.println("resultByIdList:{}"+resultByIdList);

删除有两种写法,
一种采用 id in(?,?,?)的方式
第二种采用 id = ? or id = ?
根据打印执行的具体SQL,可以看到是采用的第一种删除方式。
在这里插入图片描述

由此可见,BaseMapper实现的只是简单的增删改查功能,比如批量多条件删除就无法满足,此时还需要自己手动进行实现

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Mybatis中的<resultMap>标签用于将查询结果集中的列与Java对象属性之间进行映射。使用<resultMap>标签可以灵活地对查询结果进行映射,可以将一个查询结果映射到多个Java对象中,也可以将多个查询结果映射到一个Java对象中。 <resultMap>标签的基本语法如下: ```xml <resultMap id="resultMap" type="javaType"> <!-- Result property --> <result property="propertyName" column="columnName" /> <!-- Other Result property element --> </resultMap> ``` 其中,id属性为<resultMap>标签的唯一标识符,type属性指定映射的Java类型。 <result>标签用于指定一个Java对象属性和查询结果集中的一列之间的映射关系。其中,property属性指定Java对象属性的名称,column属性指定查询结果集中的列名。 <resultMap>标签还支持一些高级属性,例如:继承其他<resultMap>标签、自动映射、高级映射等。 继承其他<resultMap>标签可以使得<resultMap>之间形成继承关系,从而减少重复的映射定义。 自动映射可以根据Java对象属性的名称和查询结果集中的列名之间的相似度自动生成映射关系。 高级映射可以将查询结果集中的一列映射到Java对象的一个属性中,并且该属性的值是由多个列合并而成的,可以使用<association>和<collection>标签实现。 总的来说,<resultMap>标签是Mybatis中非常重要的一个标签,掌握其基本语法和高级用法对于开发高效的Mybatis应用非常有帮助。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值