开发的时候CRUD是很多的。当批量处理的时候,我们往往会纠结于这些数据是删除的还是新增的还是修改的。
这种模版式的,一直都要处理的问题。能不能抽出一些通用代码,减少每次CRUD的纠结度。在这里,我抽像出了部份重复代码。利用前台入参的数据与后台存在的数据的比较在lambda中快速找到我们要处理的数据。下面直接上代码
import java.util.List;
/**
* 根据入参与数据库存在的数据,获取可以删除、插入、更新的数据
*
* @author sven
* @version 1.0
* @since 2022/7/21
*/
public interface ICudDataService<T> {
/**
* 找到要删除的数据
*
* @param paramData
* @param dbData
* @param clazz
* @return 主键id列表
*/
List<String> getDeleteData(List<T> paramData, List<T> dbData, Class clazz);
/**
* 找到要更新的数据
*
* @param paramData
* @param dbData
* @param clazz
* @return
*/
List<T> getUpdateData(List<T> paramData, List<T> dbData, Class clazz);
/**
* 找到要新增的数据
*
* @param paramData
* @param dbData
* @param clazz
* @return
*/
List<T> getInsertData(List<T> paramData, List<T> dbData, Class clazz);
}
import cn.ICudDataService;
import org.springframework.stereotype.Service;
import java.lang.reflect.Method;
import java.util.List;
import java.util.stream.Collectors;
/**
* 根据入参与数据库存在的数据,获取可以删除、插入、更新的数据
*
* @author sven
* @since 2022/7/21
* @version 1.0
*/
@Service
public class CudDataServiceImpl<T> implements ICudDataService<T> {
private static final String MAIN_METHOD = "getId";
public List<String> getDeleteData(List<T> paramData, List<T> dbData, Class clazz) {
// 返回要删除的数据
return dbData.stream().filter(db -> !paramData.stream().anyMatch(para -> getId(db, clazz).equals(getId(para, clazz)))).map(obj -> getId(obj, clazz)).collect(Collectors.toList());
}
public List<T> getUpdateData(List<T> paramData, List<T> dbData, Class clazz) {
// 返回要更新的数据
return paramData.stream().filter(para -> dbData.stream().anyMatch(db -> getId(db, clazz).equals(getId(para, clazz)))).collect(Collectors.toList());
}
public List<T> getInsertData(List<T> paramData, List<T> dbData, Class clazz) {
// 返回要新增的数据
return paramData.stream().filter(para -> !dbData.stream().anyMatch(db -> getId(db, clazz).equals(getId(para, clazz)))).collect(Collectors.toList());
}
private String getId(T t, Class clazz) {
try {
Method getId = clazz.getMethod(MAIN_METHOD);
return (String) getId.invoke(t, null);
} catch (Exception e) {
e.printStackTrace();
}
return "";
}
}
依赖这一个接口一个类,就能根据前台传过来的入参数据,与数据库中的数据。可复用地找到我们要增加或更新或删除的数据。再进行相应orm操作就OK
PS:要看具体的生产应用,请看
JAVA实现存在更新不存在插入与及多余的进行删除(二)_jdbc 存在更新,不存在插入_wackpa的博客-CSDN博客