Java工作需求后端代码--实现树形结构

加油,新时代打工人!

前端页面
带树形结构的表格

最近在新项目上加班加点,下面是个实现树形结构的数据表格。

需求:

在前端页面表格中展示成树形结构的数据。

技术:

后端:Java、Mybatis-Plus、HuTool树形的工具类、Mysql

前端:Element UI

表结构

sql 复制代码
categoriyid	int(11)	NO	PRI		auto_increment
categoriycode	int(10)	YES	UNI		
categoriyname	varchar(50)	YES			
categoriyitemid	int(11)	YES			
status	int(2)	YES		0	
createtime	timestamp	YES		CURRENT_TIMESTAMP	DEFAULT_GENERATED
updatetime	timestamp	YES		CURRENT_TIMESTAMP	DEFAULT_GENERATED

HuTool工具类Jar

java 复制代码
<dependency>
    <groupId>cn.hutool</groupId>
    <artifactId>hutool-all</artifactId>
    <version>5.8.16</version>
</dependency>

Java实现类代码,用的Mybatis-plus,sql语句都省了

sql 复制代码
    @Autowired
	private CategoriyDao categoriyDao;
	@Override
	public List<Tree<Object>> getCategoriyList(CategoriyListVo categoriyListVo) {

		//1.没有条件查询所有的,可以根据自己的需求,加上查询条件,如查询状态已启用的
		QueryWrapper<CategoriyListVo> queryWrapper = new QueryWrapper<>();
		List<CategoriyListVo> dataList  = categoriyDao.selectList(queryWrapper);

		//2.配置
		TreeNodeConfig config = new TreeNodeConfig();
		config.setIdKey("id");      //默认id,可以不设置
		config.setParentIdKey("categoriyitemid");    //父id
		config.setNameKey("categoriyname");   //分类名称
		config.setDeep(2);      //最大递归深度
		config.setChildrenKey("children"); //孩子节点

		//3.转树
		List<Tree<Object>> treeList = TreeUtil.build(dataList, "0", config, ((object, treeNode) -> {
			treeNode.setId( object.getCategoriyid().toString());
			treeNode.setParentId(object.getCategoriyitemid().toString());
			treeNode.setName(object.getCategoriyname());
			//扩展字段
			treeNode.putExtra("categoriycode",object.getCategoriycode());//分类编码
			treeNode.putExtra("status",object.getStatus().toString());//状态
		}));
		return treeList;
	}

数据返回

相关推荐
Bat U3 小时前
JavaEE|计算机是如何工作的
java·人工智能
~plus~3 小时前
C#/.NET 8 Span与Memory高性能编程完全指南
开发语言·c#·.net
zore_c3 小时前
【C++】基础语法(命名空间、引用、缺省以及输入输出)
c语言·开发语言·数据结构·c++·经验分享·笔记
Master_清欢3 小时前
解决dify插件无限循环的问题
开发语言
许彰午3 小时前
# 政务表单动态建表?运行时DDL引擎,前端拖完字段后端直接建
java·前端·后端·架构·政务
我登哥MVP3 小时前
【Spring6笔记】 - 13 - 面向切面编程(AOP)
java·开发语言·spring boot·笔记·spring·aop
宸津-代码粉碎机3 小时前
Spring Boot 4.0 进阶实战+源码解析系列(持续更新)—— 从落地到源码,搞定面试与工作
java·人工智能·spring boot·后端·python·面试
沐雪轻挽萤3 小时前
2. C++17新特性-结构化绑定 (Structured Bindings)
java·开发语言·c++
沐知全栈开发3 小时前
PHP JSON
开发语言
java1234_小锋3 小时前
Java高频面试题:Kafka的消费消息是如何传递的?
java·开发语言·mybatis