com.baomidou.mybatisplus.extension.injector.methods.LogicDeleteBatchByIds Maven / Gradle / Ivy
/*
* Copyright (c) 2011-2022, baomidou ([email protected]).
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.baomidou.mybatisplus.extension.injector.methods;
import com.baomidou.mybatisplus.core.enums.SqlMethod;
import com.baomidou.mybatisplus.core.injector.methods.DeleteBatchByIds;
import com.baomidou.mybatisplus.core.metadata.TableFieldInfo;
import com.baomidou.mybatisplus.core.metadata.TableInfo;
import com.baomidou.mybatisplus.core.toolkit.CollectionUtils;
import com.baomidou.mybatisplus.core.toolkit.sql.SqlScriptUtils;
import java.util.List;
import static java.util.stream.Collectors.joining;
import static java.util.stream.Collectors.toList;
/**
* 试验功能,不做太复杂的功能,逻辑删除增加填充功能
*
* 如果想做的通用点的话,delete的时候如果是主键,在service层转换实体进行删除,这样根据主键删除的也能自动填充
*
* 如果是逻辑删除且标记有填充字段的情况下,以第一条记录的填充字段为准(一切以当前的时间点为基准,如果无法接受记录记录时间不准确请使用循环删除)
* 由于本身SQL更新的限制限,这里记录集合不能为空,也不支持第一条记录删除人是A或者时间是A时间,第二条记录的时间是B时间
* update table set (填充字段1,填充字段2,逻辑删除字段) where id in (主键1,主键2,主键3)
* 用法:
*
* 使用默认deleteBatchIds方法
* 注入方法: new LogicDeleteBatchByIds()
*
*
* 自定义Mapper方法名:
* 注入方法: new LogicDeleteBatchByIds("testDeleteBatch")
* 增加Mapper方法: int testDeleteBatch(@Param(Constants.COLLECTION) List entityList);
*
*
* @author nieqiurong
* @since 3.5.0
*/
public class LogicDeleteBatchByIds extends DeleteBatchByIds {
public LogicDeleteBatchByIds() {
super();
}
public LogicDeleteBatchByIds(String name) {
super(name);
}
@Override
public String logicDeleteScript(TableInfo tableInfo, SqlMethod sqlMethod) {
List fieldInfos = tableInfo.getFieldList().stream()
.filter(TableFieldInfo::isWithUpdateFill)
.filter(f -> !f.isLogicDelete())
.collect(toList());
if (CollectionUtils.isNotEmpty(fieldInfos)) {
String sqlScript = fieldInfos.stream()
.map(i -> i.getSqlSet(COLL + "[0].")).collect(joining(EMPTY));
String sqlSet = "SET " + SqlScriptUtils.convertIf(sqlScript, "[email protected]@isSimpleType(_parameter.getClass())", true)
+ tableInfo.getLogicDeleteSql(false, false);
return String.format(sqlMethod.getSql(), tableInfo.getTableName(), sqlSet, tableInfo.getKeyColumn(),
SqlScriptUtils.convertForeach(
SqlScriptUtils.convertChoose("@org.apache.ibatis.type.SimpleTypeRegistry@isSimpleType(item.getClass())",
"#{item}", "#{item." + tableInfo.getKeyProperty() + "}"),
COLL, null, "item", COMMA),
tableInfo.getLogicDeleteSql(true, true));
} else {
return super.logicDeleteScript(tableInfo, sqlMethod);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy