Mybatis实现树形结构方式

 1,三级分类树形结构查询

/**
 * DDD(Domain-Driven Design): 领域驱动设计
 *
 * 三级分类树形结构;
 * 支持无限层级;
 * 当前项目只有三级
 */
@Data
public class CategoryTreeTo {
   private  Long categoryId; //1
   private String categoryName;
   private List<CategoryTreeTo>  categoryChild;//子分类
}
   <!--    定义Category树形封装规则; 三级固定封装-->
    <resultMap id="CategoryTreeRM" type="com.azxc.rapid.modules.main.dto.CategoryTreeTo">
        <!--     一级分类的规则   -->
        <id column="id" property="categoryId"></id>
        <result column="name" property="categoryName"></result>
        <collection property="categoryChild"
                    ofType="com.azxc.rapid.modules.main.dto.CategoryTreeTo">
            <!--  二级分类封装规则 -->
            <id column="c2_id" property="categoryId"></id>
            <result column="c2_name" property="categoryName"></result>
            <collection property="categoryChild"
                        ofType="com.azxc.rapid.modules.main.dto.CategoryTreeTo">
                <!--  三级分类封装规则 -->
                <id column="c3_id" property="categoryId"></id>
                <result column="c3_name" property="categoryName"></result>
            </collection>
        </collection>
    </resultMap>
    <select id="getTest" resultMap="CategoryTreeRM">
        select bc1.*,
               bc2.id   c2_id,
               bc2.name c2_name,
               bc2.category1_id,
               bc3.id   c3_id,
               bc3.name c3_name,
               bc3.category2_id
        from base_category1 bc1
                 left join base_category2 bc2 on bc1.id = bc2.category1_id
                 left join base_category3 bc3 on bc2.id = bc3.category2_id
    </select>

执行结果展示

 

 2,树形结构(递归遍历)

    @Override
    public List<Permission> getTest1() {
        //查询所有菜单
        List<Permission> res = baseMapper.getTest1();
        return build(res);
    }

    /**
     * 根据权限列表构建父子关系
     *
     * @param permissionList
     * @return
     */
    public static List<Permission> build(List<Permission> permissionList) {
        List<Permission> menu = new ArrayList<>();
        for (Permission permission : permissionList) {
            //判断当前菜单是否是以及菜单
            if (permission.getParentId() == 0) {
                //一级菜单
                //2.1 设置一级菜单的子菜单列表
                permission.setChildren(getChildren(permission, permissionList));
                //2.2 将一级菜单添加到菜单列表中
                menu.add(permission);
            }
        }
        return menu;
    }


    /**
     * 从原始菜单中获取某个权限的子菜单列表
     *
     * @param permission
     * @param originPermissionList
     * @return
     */
    private static List<Permission> getChildren(Permission permission, List<Permission> originPermissionList) {
        //1. 创建一个新的集合,用来存储子菜单
        List<Permission> children = new ArrayList<>();
        //1. 遍历出原始菜单中的每一个权限
        for (Permission child : originPermissionList) {
            //1.1 如果originPermission的父id等于permission的id
            if (permission.getId().equals(child.getParentId())) {
                //originPermission是permission的子菜单,则将originPermission添加到children中
                // 子菜单还有没有子菜单呢?
                child.setChildren(getChildren(child, originPermissionList));
                children.add(child);
            }
        }
        return children;
    }

结果 :

 表结构:树形结构

3,数据字典

需求效果图

 表结构:树形结构

 1.xml

    <select id="findListByParentId" resultType="com.atguigu.entity.Dict">
        <include refid="columns"></include>
        from hse_dict
        where parent_id = #{parentId} and is_deleted = 0
    </select>

2.业务层

    @Override
    public List<Map<String, Object>> findZnodes(Long id) {
        //根据id查询对应的子分类
        List<Dict> dictList = dictMapper.findListByParentId(id);
        //使用Stream API将dictList转换为Map集合
        List<Map<String, Object>> zNodes = dictList.stream()
                .map(dict -> {
                    Map<String, Object> responseMap = new HashMap<>();
                    //表示当前节点是否还有子节点,以当前节点的id到hse_dict表中查询子节点的数量,如果大于0,则表示当前节点还有子节点
                    Integer count = dictMapper.countIsParent(dict.getId());
                    responseMap.put("isParent", count > 0);
                    //表示当前节点的名称
                    responseMap.put("name", dict.getName());
                    responseMap.put("id", dict.getId());
                    return responseMap;
                })
                .collect(Collectors.toList());
        return zNodes;
    }

 

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

外观数列 ---- 模拟

题目链接 题目: 分析: 题目的意思如下:所以我们需要引用双指针来找到连续的字符有几个, 并添加到答案中, 接着将此字符添加到答案中, 让left right , 继续向后遍历整个字符串, 重复上面的操作将答案重新赋给字符串, 继续重复上述操作, 应该重复n - 1 次, 因为n为1的时候, 直…

上网是不是必须路由器和光猫之一负责拨号?

链接&#xff1a;https://www.zhihu.com/question/624856022/answer/3245182557 上网并非一定要“拨号”&#xff0c;使用固定IP地址可以直接上网&#xff0c;不需要拨号。你们公司的宽带属于商用宽带&#xff0c;运营商&#xff08;电信&#xff09;给配置了固定的IP&#…

如何监控企业微信聊天记录内容,第二个方法太赞了!

监控企业微信聊天记录内容是企业为了确保沟通合规、提升工作效率、防止信息泄露以及保护公司利益而采取的一种管理措施。在当前的中国&#xff0c;是法律允许的合法行为。 怎么监控&#xff1f;请看下面详情。 1. 利用企业微信自带功能 企业会话存档&#xff1a; 企业微信提…

43页 | 2024年企业级BI平台白皮书(免费下载)

【1】关注本公众号&#xff0c;转发当前文章到微信朋友圈 【2】私信发送 2024年企业级BI平台白皮书 【3】获取本方案PDF下载链接&#xff0c;直接下载即可。 诚挚邀请您微信扫码加入以下方案驿站知识星球&#xff0c;获取上万份PPT/WORD解决方案&#xff01;&#xff01;&…

【Python Cookbook】S01E16 同时对数据做转换和换算

目录 问题解决方案讨论 问题 当换算&#xff08;sum(), min(), max()&#xff09;同时遇到转换或筛选&#xff0c;怎么做&#xff1f; 解决方案 有一种非常优雅的方法&#xff0c;可以将数据换算和转换结合在一起——在函数参数中使用 生成器表达式。 一个直观的案例&#…

YOLOv8+PyQt5海洋船只检测(可以重新训练,yolov8模型,从图像、视频和摄像头三种路径识别检测)

1.效果视频&#xff1a;海洋船只检测yoloV8检测&#xff08;https://mbd.pub/o/bread/mbd-ZpaYk55r&#xff09;_哔哩哔哩_bilibili资源包含可视化的海洋船只检测系统&#xff0c;可对于高空拍摄到的海洋图片进行轮船检测&#xff0c;基于最新的YOLOv8训练的海洋船只检测模型&a…

Facebook开户|FB10大提升视频广告效果实践

Facebook10大提升视频广告效果实践&#xff01;&#xff01;需要的家人们建议点赞收藏哦~ 一、在前3秒吸引注意力 在视频广告推广活动中&#xff0c;一直都有黄金3秒的说法&#xff0c;指的就是通过前三秒的制作&#xff0c;吸引观众的注意。吸引人的画面、个性的CTA、独特性和…

C语言| 字母金字塔

【思路分析&#xff1a;】 1 考虑左边的空格大写字母&#xff0c;而大写字母 先升序后降序输出 2 升序输出的字母的个数行数最大字母在26个英文字母中排的位置序号 3 降序输出的字母 升序输出的字母个数-1 编程顺序&#xff1a; 1 定义循环变量i,表示字母的顺序,循环变量j 表…

软件测试之黑盒测试与白盒测试知识小结

&#x1f345; 视频学习&#xff1a;文末有免费的配套视频可观看 &#x1f345; 点击文末小卡片&#xff0c;免费获取软件测试全套资料&#xff0c;资料在手&#xff0c;涨薪更快 对于很多刚开始学习软件测试的小伙伴来说&#xff0c;如果能尽早将黑盒、白盒测试弄明白&#xf…

Makefile的入门学习

一、Makefile的入门学习 编译工具及构建工具介绍 在之前的课程&#xff0c;都是直接使用gcc对代码进行编译&#xff0c;这对简单的工程是可以的&#xff0c;但当我们遇到复杂的工程时&#xff0c;每次用gcc等编译工具去操作就会显得很低效。因此make工具就出现了&#xff0c;…

MYSQL之主从复制

一&#xff0c;安装MYSQL&#xff0c;两台 二&#xff0c;配置master服务器 vim /etc/my.cnf 在mysqld模块下加入 server-id133 #配置server-id&#xff0c;让主服务器有唯一ID号&#xff08;让从服务器知道 他的主服务器是谁&#xff09;,建议使用ip最后3位 log-binmysql-bi…

coze扣子自定义插件开发

之前用过阿里云的&#xff0c;阿里云的插件填写的内容有点复杂 今天体验coze&#xff0c;没想到如此简单&#xff1b; 访问地址&#xff1a;扣子&#xff0c;注册对应账户&#xff0c;并创建对应空间&#xff1b; 第一步&#xff1a;点击插件&#xff0c;新建插件 选择不需要…

OpenHarmony嵌套类对象属性变化:@Observed装饰器和@ObjectLink装饰器

上文所述的装饰器仅能观察到第一层的变化&#xff0c;但是在实际应用开发中&#xff0c;应用会根据开发需要&#xff0c;封装自己的数据模型。对于多层嵌套的情况&#xff0c;比如二维数组&#xff0c;或者数组项class&#xff0c;或者class的属性是class&#xff0c;他们的第二…

代码随想录算法训练营第四十八天 | 70. 爬楼梯 (进阶)、322. 零钱兑换、279.完全平方数

70. 爬楼梯 &#xff08;进阶&#xff09; 代码随想录 解题思路 1.确定dp数组以及下标的含义 dp[i]&#xff1a;爬到有i个台阶的楼顶&#xff0c;有dp[i]种方法 2.递推公式 dp[j] dp[j - nums[i] ] 装满背包有多少种方法一般用这个 3.遍历顺序 完全背包&#xff0c;且…

Java面试——中间件

OpenFeign 1、openFeign是一个HTTP客户端&#xff0c;它融合了springmvc的注解&#xff0c;使之可以用REST风格的映射来请求转发。 2、可以把openFegin理解为是controller层或是service层。可以取代springmvc控制层作为请求映射&#xff0c;亦或是作为service层处理逻辑&#…

《网络安全技术 生成式人工智能服务安全基本要求》征求意见稿

1. 训练数据安全要求 &#xff08;1&#xff09;数据来源安全&#xff1a; 采集来源管理&#xff1a; 采集数据前应进行安全评估&#xff0c;含违法不良信息超过5%的数据源不得使用。 采集后需核验&#xff0c;含违法不良信息超过5%的数据不得用于训练。 不同来源训练数据搭…

kafka-集群-主题创建

文章目录 1、集群主题创建1.1、查看 efak1.2、创建 主题 my_topic1 并建立6个分区并给每个分区建立3个副本1.2.1、查看 my_topic1 的详细信息 1.3、停止 kafka-01实例&#xff0c;端口号为 9095 1、集群主题创建 1.1、查看 efak 已经有三个kafka实例 1.2、创建 主题 my_topic1…

C语言(数据存储)

Hi~&#xff01;这里是奋斗的小羊&#xff0c;很荣幸各位能阅读我的文章&#xff0c;诚请评论指点&#xff0c;欢迎欢迎~~ &#x1f4a5;个人主页&#xff1a;小羊在奋斗 &#x1f4a5;所属专栏&#xff1a;C语言 本系列文章为个人学习笔记&#xff0c;在这里撰写成文一…

windows上安装jdk1.8

这篇文章详细地介绍如何在windows上安装jdk1.8 目录 准备工作 第一步 第二步 第三步 第四步 第五步 最后的效果 查看JDK版本 准备工作 下载jdk&#xff1a;通过官网或者以下百度网盘链接下载jdk1.8 链接&#xff1a;https://pan.baidu.com/s/1zuMl0B-S6SDgiu1evw-IPQ?…

React useContext源码分析

React 框架中 useContext Hook 用于数据的传递&#xff0c;组件的数据传递有几种方式&#xff0c;通过 props、状态管理 和 useContext。本文将讲述useContext 在 React 是如何工作的&#xff0c;创建一个简单的 Context 例子并根据源码进行 Debug&#xff1a; 创建 context …