对比两个集合,取交集,并集,差集,进行CRUD操作

entity 和 controller 和 dao 不提供了。

主要提供两个集合,取交集,并集,差集,进行CRUD操作的思路

交集,并集,差集,进行对应CRUD操作因需求而定

Spring Boot+MyBatis-Plus项目

废话不多说,上代码:

    @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("更新成功");
	}

经过测试是没有问题的。

如有问题或者有更好的方式,欢迎大家指点迷津。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值