当前位置: 首页 > news >正文

Mysql 递归查询所有子节点,hutool树形结构封装

工作中经常会有像目录,部门的多级结构,记录一下查询自己点的方式,留着复制粘贴

方式1:

SELECT* 
FROMcus_department 
WHEREFIND_IN_SET( id, @pid ) > 0;UNIONSELECTcd.* 
FROM( SELECT * FROM cus_department WHERE pid IS NOT NULL AND deleted = 0 ) cd,( SELECT @pid := '1742370890433187841' ) pd 
WHEREFIND_IN_SET( pid, @pid ) > 0 AND @pid := concat( @pid, ',', id ) 

UNION 上方包括了自己,只查下级可去掉
需要替换的有
表名:cus_department
查询条件:deleted = 0
父id字段名称:pid
主键名称:id

方式2:

SELECT* 
FROM(SELECTc1.*,IF( FIND_IN_SET( pid, @parent_ids ) > 0, @parent_ids := CONCAT( @parent_ids, ',', id ), '0' ) AS ischild FROM( SELECT * FROM cus_department AS cd WHERE cd.deleted = 0  ORDER BY cd.id ASC ) c1,( SELECT @parent_ids := '1742370890433187841' ) c2 ) c3 
WHEREischild != '0'

此方式只查下级

需要替换的有
表名:cus_department
查询条件:deleted = 0
父id字段名称:pid
主键名称:id

方式3:

	SELECTrd.* 
FROM( SELECT * FROM cus_department WHERE pid IS NOT NULL AND deleted = 0 ) rd,( SELECT @p_id := '1742370890433187841' ) pd 
WHEREFIND_IN_SET( pid, @p_id ) > 0 AND @p_id := concat( @p_id, ',', id ) 

此方式只查下级
需要替换的有:
表名:cus_department
查询条件:deleted = 0
父id字段名称:pid
主键名称:id

使用hutool快速构建树形结构

引入依赖

<dependency><groupId>cn.hutool</groupId><artifactId>hutool-all</artifactId><version>5.7.17</version></dependency>

代码

      //配置TreeNodeConfig treeNodeConfig = new TreeNodeConfig();treeNodeConfig.setIdKey("id");//设置父类idtreeNodeConfig.setParentIdKey("pid");//设置排序字段treeNodeConfig.setWeightKey("orderr");//设置树形结构子类treeNodeConfig.setChildrenKey("children");List<Tree<String>> treesNodes = TreeUtil.build(cusDepartments, "0", treeNodeConfig,(result, tree) -> {//设置idtree.setId(String.valueOf(result.getId()));tree.setParentId(String.valueOf(result.getPid()));tree.setName(result.getName());//设置其他字段tree.putExtra("level", result.getLevel());tree.putExtra("createTime",DateUtil.format(result.getCreateTime(), "yyyy-MM-dd"));tree.putExtra("orderr", result.getOrderr());});
http://www.lryc.cn/news/279877.html

相关文章:

  • 【代码随想录04】24. 两两交换链表中的节点 19. 删除链表的倒数第 N 个结点 面试题 02.07. 链表相交 142. 环形链表 II
  • Pandas实战100例 | 案例 25: 计算相关系数
  • vue文本识别“\n“换行问题的解决方式
  • 【QT-UI】
  • MyBatisPlus逆向工程
  • 创建ESP32开源WiFi MAC(介质访问控制)层
  • LeetCode 2723. 两个 Promise 对象相加
  • Flutter--常用技术文档
  • 行分类问题
  • java常见面试题:如何使用Java进行XML解析和生成?
  • 【LabVIEW FPGA入门】LabVIEW FPGA实现I2S解码器
  • linux 安装sipp
  • c++最值查找
  • xtu-c语言考试复习-2
  • MySQL决战:MySQL数据导入导出
  • Unity 面试篇|(二)Unity基础篇 【全面总结 | 持续更新】
  • TIDB的忘了root用户密码和数据库密码解决办法
  • QT基础篇(4)QT5基本对话框
  • Springboot项目Nacos做配置中心
  • SpringSecurity入门demo(三)多用户身份认证
  • 【设计模式-02】Strategy策略模式及应用场景
  • ssh远程登陆
  • go如何终止多个for select循环嵌套
  • nginx(1.13.7)首次安装出现:【make: *** 没有规则可以创建“default”需要的目标“build” 问题】解决措施
  • 2024.1.8 关于 Redis 数据类型 Zset 集合命令、编码方式、应用场景
  • ffmpeg[学习(四)](代码实现) 实现音频数据解码并且用SDL播放
  • C++ 字符串哈希 || 字符串前缀哈希法
  • 【java】项目部署liunx服务器的简单步骤
  • 深度学习笔记(五)——网络优化(1):学习率自调整、激活函数、损失函数、正则化
  • 鸿蒙开发现在就业前景怎样?