entity 和 controller 和 dao 不提供了。
主要提供两个集合,取交集,并集,差集,进行CRUD操作的思路
交集,并集,差集,进行对应CRUD操作因需求而定
废话不多说,上代码:
@Override
public R put(Long mid, List<Fields> fields) {
//前台提交的数据,放入集合l
List<Fields> l=new ArrayList<>();
for (Fields fields1 : fields){
l.add(new Fields(fields1.getType(),fields1.getName(),fields1.getLabel()));
}
//从数据库获取mid对应的多条数据
QueryWrapper qw=new QueryWrapper<>();
qw.eq("mid",mid);
List<Fields> fields1=fieldsMapper.selectList(qw);
List<Fields> l1=new ArrayList<>();
//数据库获取mid对应的多条数据放入集合l1(这里我只要这三个字段)
for (Fields f : fields1){
l1.add(new Fields(f.getType(),f.getName(),f.getLabel()));
}
//对比两个集合l和l1
//取交集 执行更新
List<Fields> in=l.stream().filter(item -> l1.contains(item)).collect(toList());
if (in.size() != 0){
for (Fields i : in){
fieldsMapper.updateById(i);
}
}
//取差集 提交l --> 数据库l1 添加提交数据(mid对应数据库没有的)
List<Fields> re1=l.stream().filter(item -> !l1.contains(item)).collect(toList());
if (re1.size() != 0){
for (Fields re : re1){
fieldsMapper.insert(re);
}
}
//取差集 数据库l1 --> 提交l 删除数据库数据(mid对应数据库多余的数据)
List<Fields> re2=l1.stream().filter(item -> !l.contains(item)).collect(toList());
if (re2.size() != 0){
Map<String,Object> map=new HashMap<>();
for (Fields re : re2){
map.put("type",re.getType());
map.put("name",re.getName());
map.put("mid",mid);
map.put("label",re.getLabel());
//同时满足type,name,mid,label字段值进行删除
fieldsMapper.deleteByMap(map);
}
}
return R.ok("更新成功");
}
经过测试是没有问题的。
如有问题或者有更好的方式,欢迎大家指点迷津。