All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.baomidou.mybatisplus.extension.injector.methods.LogicDeleteBatchByIds Maven / Gradle / Ivy

There is a newer version: 3.5.2.2
Show newest version
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(COLLECTION + "[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() + "}"), COLLECTION, null, "item", COMMA), tableInfo.getLogicDeleteSql(true, true)); } else { return super.logicDeleteScript(tableInfo, sqlMethod); } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy