菜单子节点的写法

菜单子节点的写法

  • 1.测试数据
  • 2.实现代码
  • 3.获取父ID层级

1.测试数据

1.表结构SQL

CREATE TABLE `test` (`id` int DEFAULT NULL,`u_id` int DEFAULT NULL,`p_u_id` int DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;

2.数据SQL

INSERT INTO test (id,u_id,p_u_id) VALUES(1,1,0),(2,2,0),(3,3,0),(4,11,1),(5,12,1),(6,21,2),(7,22,2),(8,211,21),(9,221,22),(10,222,22),(11,223,22),(12,2231,223),(13,2232,223),(14,0,-1);

3.查询表数据

select * from test;

在这里插入图片描述

2.实现代码

1.pojo代码

@TableName("test")
@Data
public class Test implements Serializable {private Integer id;private Integer uId;private Integer pUId;@TableField(exist = false)private List<Test> testChains;@TableField(exist =false)private String treeId;}

2.service层代码

    @Overridepublic List<String> treeIds() {List<Test> list = this.list();return list.stream().filter(e -> e.getPUId() == -1).peek((tId) -> {tId.setTestChains(getChildren(tId, list));}).toList();}private List<Test> getChildren(Test test, List<Test> all) {return all.stream().filter(x->x.getPUId() != null).filter(categoryEntity -> {return categoryEntity.getPUId().equals(test.getUId());}).peek(treeId -> {treeId.setTestChains(getChildren(treeId, all));}).collect(Collectors.toList());}
}

3.测试结果

[{"id": 14,"testChains": [{"id": 1,"testChains": [{"id": 4,"testChains": [],"treeId": null,"puid": 1,"uid": 11},{"id": 5,"testChains": [],"treeId": null,"puid": 1,"uid": 12}],"treeId": null,"puid": 0,"uid": 1},{"id": 2,"testChains": [{"id": 6,"testChains": [{"id": 8,"testChains": [],"treeId": null,"puid": 21,"uid": 211}],"treeId": null,"puid": 2,"uid": 21},{"id": 7,"testChains": [{"id": 9,"testChains": [],"treeId": null,"puid": 22,"uid": 221},{"id": 10,"testChains": [],"treeId": null,"puid": 22,"uid": 222},{"id": 11,"testChains": [{"id": 12,"testChains": [],"treeId": null,"puid": 223,"uid": 2231},{"id": 13,"testChains": [],"treeId": null,"puid": 223,"uid": 2232}],"treeId": null,"puid": 22,"uid": 223}],"treeId": null,"puid": 2,"uid": 22}],"treeId": null,"puid": 0,"uid": 2},{"id": 3,"testChains": [],"treeId": null,"puid": 0,"uid": 3}],"treeId": null,"puid": -1,"uid": 0}
]

3.获取父ID层级

1.pojo代码

@TableName("test")
@Data
public class Test implements Serializable {private Integer id;private Integer uId;private Integer pUId;@TableField(exist = false)private List<Test> testChains;@TableField(exist =false)private String treeId;}

2.service层代码

 @Overridepublic List<String> treeIds() {List<Test> list = this.list();List<Test> collect = list.stream().peek((tId) -> {tId.setTreeId(tId.getUId().toString());tId.setTestChains(getChildren(tId, list));}).toList();return collect.stream().map(Test::getTreeId).toList();}private List<Test> getChildren(Test test, List<Test> all) {return all.stream().filter(x->x.getPUId() != null).filter(categoryEntity -> {return categoryEntity.getPUId().equals(test.getUId());}).peek(treeId -> {treeId.setTreeId((test.getTreeId() == null? test.getUId() : test.getTreeId())+"/"+treeId.getUId());treeId.setTestChains(getChildren(treeId, all));}).collect(Collectors.toList());}

3.测试结果

["0/1","0/2","0/3","0/1/11","0/1/12","0/2/21","0/2/22","0/2/21/211","0/2/22/221","0/2/22/222","0/2/22/223","0/2/22/223/2231","0/2/22/223/2232","0"
]

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/128672.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【EI会议征稿】第三届智慧交通、能源与动力国际学术会议(STEP 2023)

第三届智慧交通、能源与动力国际学术会议&#xff08;STEP 2023&#xff09; 2023 3rd International Conference on Smart Transportation, Energy and Power 第三届智慧交通、能源与动力国际学术会议 (STEP 2023) 将于2023年12月15-17日在中国三亚市隆重举行&#xff0c;会议…

tcpdump(四)命令行参数讲解(三)

一 BPF高级过滤条件 高级filter官方地址 常见需求案例汇总 过滤的目的&#xff1a;获取最精细、准确的数据思考&#xff1a; 抓取更精确的包?1) tcp/ip 报文结构要精通,这样才能知道如何获取自己想要的信息 -> 偏移量2) tcpdump 的synax语法要精通,要正确写对3) 多练习…

docker入门加实战—docker安装并配置阿里云加速

docker入门加实战—docker安装并配置阿里云加速 为什么要学习docker 在开发和部署项目的过程中&#xff0c;经常会遇到如下问题&#xff1a; 软件安装包名字复杂&#xff0c;不知道去哪里找安装软件和部署项目步骤复杂&#xff0c;容易出错 这就是我们今天要学习Docker技术…

29 WEB漏洞-CSRF及SSRF漏洞案例讲解

目录 CSRF漏洞解释&#xff0c;原理等CSRF漏洞检测&#xff0c;案例&#xff0c;防御等防御方案2、设置随机Token3、检验referer来源 SSRF漏洞会比csrf漏洞重要一些SSRF_PHP&#xff0c;JAVA漏洞代码协议运用演示案例:SSRF_漏洞代码结合某漏洞利用测试 如何查找ssrf漏洞 SSRF漏…

k8s-9 ingress-nginx 特性

TLS加密 创建证书 测试 auth认证 创建认证文件 rewrite重定向 进入域名 会自动重定向hostname.html 示例二&#xff1a; 测试 后面必须跟westos 这个关键字 canary金丝雀发布 基于header灰度 场景&#xff1a;版本的升级迭代&#xff0c;比如一个service 升级到另…

Windows安装Node.js

1、Node.js介绍 ①、Node.js简介 Node.js是一个开源的、跨平台的JavaScript运行环境&#xff0c;它允许开发者使用JavaScript语言来构建高性能的网络应用程序和服务器端应用。Node.js的核心特点包括&#xff1a; 1. 事件驱动: Node.js采用了事件驱动的编程模型&#xff0c;通…

如何对比github中不同commits的区别

有时候想要对比跨度几十个commits之前的代码区别&#xff0c;想直接使用github的用户界面。可以直接在官网操作。 示例 首先要创建一个就commit的branch。进入该旧的commit&#xff0c;然后输入branch名字即可。 然后在项目网址后面加上compare即可对比旧的branch和新的bran…

MQTT服务器源码解析

目录 1、关于header问题 2、MQTT 连接参数的使用 2.1连接地址 2.2 基于 TCP 的 MQTT 连接 2.3 基于 WebSocket 的连接 3、订阅topic 4、推送消息给订阅者 5、QOS 机制 5.1 QOS是什么 5.2 QOS的实现原理 5.3 发送流程 6、reatain机制 总结&#xff1a;给还没上线的…

智慧工地:数字革命下的建筑业新趋势

在当今建筑领域&#xff0c;智慧工地正迅速崭露头角。这个概念不仅代表了技术进步&#xff0c;还预示着建筑行业的数字化和智能化未来。从多个角度来看&#xff0c;智慧工地都具有深远的意义&#xff0c;它正在改变着我们建筑的方式和未来。 提高工程效率 智慧工地利用物联网&…

软件工程与计算总结(五)软件需求基础

本帖介绍软件需求涉及的诸多基本概念&#xff0c;通过对这些概念的阐述&#xff0c;剖析软件需求的来源、层次、类别、作用等重要知识~ 目录 ​编辑 一.引言 二.需求工程基础 1.简介 2.活动 3.需求获取 4.需求分析 5.需求规格说明 6.需求验证 7.需求管理 三.需求基…