【java】生成树形结构及条件搜索

java中使用递归快速构建树形数据结构

1,数据表设计

在设计表时每个记录中应添加parentId字段,用于标识父子关系。

2,实体类

java 复制代码
public class Entity {

	private Long id;

	private Long parentId;

	private List<Entity> children = Lists.newArrayList();
	
	// 省略其他属性及get、set方法
	
}

3,service

java 复制代码
// 常量 标识第一层级的父id
	private final static Long ROOT_PARENT_ID = 0L;
	
	/**
	 * 获取树形结构
	 * @param condition 筛选条件
	 * @return
	 */
	public List<Entity> loadTreeData(Condition condition) {
		List<Entity> entityList = this.dealTreeData(ROOT_PARENT_ID,condition);
		return entityList;
	}

	private List<Entity> dealTreeData(Long parentId,condition condition){
		// 获取所有的数据表记录
		List<Entity> allItems = EntityMapper.getAllItems();
		if(CollectionUtils.isEmpty(allItems)) {
			return Lists.newArrayList();
		}
		// 递归方法
		List<Entity> tree = this.getTree(allItems, parentId);
		// 条件筛选
		this.treeMatch(tree,condition);
		return tree;
	}

	private List<Entity> getTree(List<Entity> allItems,Long parentId){
		List<Entity> tree = new ArrayList<>();
		for(Entity entity:allItems){
			if(entity.getParentId() == parentId){
				entity.setChildren(getTree(allItems,entity.getId()));
				tree.add(entity);
			}
		}
		return tree;
	}

	public void treeMatch(List<Entity> allTree, condition condition){
		Iterator<Entity> iter = allTree.iterator();
		while (iter.hasNext()){
			// 获取当前遍历到的目录
			Entity entity = iter.next();
			boolean shouldRemove = true;
			// 如果当前目录名称包含关键字,则什么也不做(不移除),否则就看下一级
			if(StringUtils.hasText(condition.getCondition1()) && !entity.getCondition1().equals(condition.getCondition1())){
				// 取出下一级目录集合
				List<Entity> childrenList = entity.getChildren();
				// 递归
				if(!CollectionUtils.isEmpty(childrenList)){
					treeMatch(childrenList,condition);
				}
			} else if(StringUtils.hasText(condition.getCondition2()) && !entity.getCondition2().equals(condition.getCondition2())){
				// 取出下一级目录集合
				List<Entity> childrenList = entity.getChildren();
				// 递归
				if(!CollectionUtils.isEmpty(childrenList)){
					treeMatch(childrenList,condition);
				}

			} else {
				shouldRemove = false;
			}

			// 下一级目录看完了,如果下一级目录全部被移除,则移除当前目录
			if(CollectionUtils.isEmpty(entity.getItems()) && shouldRemove){
				iter.remove();
			}

		}
	}
相关推荐
郝学胜-神的一滴15 分钟前
使用OpenGL绘制卡通效果的圣诞树
开发语言·c++·程序人生·游戏·图形渲染
想不明白的过度思考者19 分钟前
Spring Boot 配置文件深度解析
java·spring boot·后端
第二只羽毛22 分钟前
Java图书管理系统的设计与实现
java·大数据·安全·系统安全
想回家的一天5 小时前
ECONNREFUSED ::1:8000 前端代理问题
开发语言
cike_y5 小时前
Mybatis之解析配置优化
java·开发语言·tomcat·mybatis·安全开发
Jay_Franklin7 小时前
SRIM通过python计算dap
开发语言·python
是一个Bug7 小时前
Java基础50道经典面试题(四)
java·windows·python
Slow菜鸟7 小时前
Java基础架构设计(三)| 通用响应与异常处理(分布式应用通用方案)
java·开发语言
消失的旧时光-19437 小时前
401 自动刷新 Token 的完整架构设计(Dio 实战版)
开发语言·前端·javascript
wadesir7 小时前
Rust中的条件变量详解(使用Condvar的wait方法实现线程同步)
开发语言·算法·rust