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

融资项目——获取树形结构的数据

如下图所示,下列数据是一个树形结构数据,行业中包含若干子节点。表的设计如下图,设置了一个id为1的虚拟根节点。(本树形结构带虚拟根节点共三层)

实现逻辑:

延时展示方法,先展现第二层的信息,如果想要看到具体第三层的信息,点击按钮触发后台请求,通过当前点击的父节点获得其所有子节点。

实现方法:

0. 首先在Dict实体类中加入如下属性:

 @TableField(exist = false)//逻辑概念的属性,与物理表没有关系,数据库表中不存在该字段。
    private boolean hasChildren;

1.Service层:

    @Override
    public List<Dict> listByParentId(Long parentId) {
        QueryWrapper<Dict> queryWrapper=new QueryWrapper<>();
        queryWrapper.eq("parent_id",parentId);
        List<Dict> dictList= dictMapper.selectList(queryWrapper);
        //填充hasChildren字段
        dictList.forEach(dict -> {
            //判断当前字段是否有子节点
            dict.setHasChildren(this.hasChildre(parentId));
        });
        return dictList;
    }

//    判断当前节点下是否存在子节点
    private  boolean hasChildre(Long id){
        QueryWrapper<Dict> queryWrapper=new QueryWrapper<>();
        queryWrapper.eq("parent_id",id);
        Integer count=dictMapper.selectCount(queryWrapper);
        if(count>0)return true;
        else return false;
    }

2. Controller层:

@ApiOperation("根据上级id获取所有子节点信息")
    @GetMapping("/listByParentId/{parentId}")
    public R listByParentId(@ApiParam(value = "上级父节点的id")@PathVariable Long parentId){
        List<Dict> dictList=dictService.listByParentId(parentId);
        return R.ok().data("list",dictList);
    }

相关文章:

  • MyBatis之Like模糊查询的两种实现方式
  • A股上市以来涨幅排行榜
  • 2024刘谦春晚第二个扑克牌魔术
  • [Python进阶] 识别验证码
  • tkinter-TinUI-xml实战(10)展示画廊
  • 第三百一十回
  • JUnit实践教程——Java的单元测试框架
  • c语言贪食蛇游戏
  • python Flask与微信小程序 统计管理
  • 【Linux学习】生产者-消费者模型
  • 【FPGA】VHDL:八段码到8421BCD码转换电路
  • idea:如何连接数据库
  • Nacos 的配置管理和配置热更新
  • 鸿蒙内核框架
  • Cohere For AI 推出了 Aya,这是一款覆盖超过 100 种语言的大型语言模型(LLM)
  • MATLAB实现朴素贝叶斯分类
  • Mysql报错:too many connections
  • PyTorch detach():深入解析与实战应用
  • Javaweb之SpringBootWeb案例之AOP概述及入门的详细解析
  • 双非本科准备秋招(19.2)—— 设计模式之保护式暂停
  • 即日起,“应急使命·2025”演习公开征集新质救援能力
  • 金砖国家外长会晤主席声明(摘要)
  • 过去24小时中美是否就关税问题进行过接触?外交部:没有
  • 陕西省通报6起违反八项规定典型问题,省卫健委原主任刘宝琴违规收受礼品礼金
  • 神舟十九号载人飞行任务取得圆满成功
  • 狄威已任国铁集团副总经理