//应用场景:批量添加权限,表中userId和roleId相同则认为数据相同不插入,需要从数据中过滤出需要插入的数据
public void study(){
//需要插入的实体
ArrayList<ExampleUserEntity> exampleUserEntity = null;
//数据库中过滤过只有含有exampleUserEntity的userId的数据
List<ExampleUserEntity> exampleUserEntities = null;
//过滤出需要插入的数据,这里就是过滤多个相同字段
List<ExampleUserEntity> collect = exampleUserEntity.stream().filter(e -> {
for (ExampleUserEntity sysRoleUserEntity : exampleUserEntities) {
if (e.getUserId().equals(sysRoleUserEntity.getUserId()) && e.getRoleId().equals(sysRoleUserEntity.getRoleId())) {
return false;
}
}
return true;
}).collect(Collectors.toList());
//collect中就是需要插入的数据
}
Stream的filter比较两个list中多个字段相同的过滤掉
最新推荐文章于 2024-06-01 08:51:50 发布