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,可以看到是采用的第一种删除方式。