手动实现一个树结构(根据参数ID返回当前节点以及所有子节点,递归查询下一级节点)

本文介绍了一种使用Java实现树形结构的方法,通过递归地为每个节点设置子节点来构建树形数据结构。该方法利用了Java 8的Stream API进行数据处理,并展示了如何从数据库获取数据并形成树状显示。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

package com.study.utils;

import com.study.entity.Per;

import java.util.Comparator;
import java.util.List;
import java.util.stream.Collectors;

public class TreeUtils {

    public static Per getCurrentNode(List<Per> list){
        Per per = list.stream().min(Comparator.comparing(Per::getId)).get();

        return setChildrenNode(per, list);
    }
    public static Per setChildrenNode(Per per,List<Per> list){
        List<Per> collect = list.stream().filter(item -> {
            return per.getId().equals(item.getPid());
        }).collect(Collectors.toList());

        per.setPerList(collect);

        if(collect.size()!=0){
            collect.stream().forEach(item -> {setChildrenNode(item,list);});
        }

        return per;
    }
}



package com.study.entity;

import lombok.Data;

import javax.persistence.*;
import java.util.List;

@Data
@Entity
@Table(name = "per")
public class Per {
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Integer id;
    private Integer pid;
    @Transient
    private List<Per> perList;
}



package com.study;

import com.alibaba.fastjson.JSON;
import com.study.dao.PerRepository;
import com.study.entity.Per;
import com.study.utils.TreeUtils;
import org.junit.jupiter.api.Test;
import org.springframework.boot.test.context.SpringBootTest;

import javax.annotation.Resource;
import java.util.ArrayList;
import java.util.List;

@SpringBootTest
class JpaApplicationTests {

	@Resource
	private PerRepository perRepository;

	@Test
	void test(){
		List<Per> collect = new ArrayList<>();
		List<Per> list = getList(collect,2);
		Per currentNode = TreeUtils.getCurrentNode(list);
		JSON o = (JSON)JSON.toJSON(currentNode);
		System.out.println(o);

	}

	public List<Per> getList(List<Per> list,Integer id){
		Per per = perRepository.findById(id).get();
		if(per!=null){
			list.add(per);
		}
		List<Per> children = perRepository.findByPid(per.getId());
		children.stream().forEach(item ->{getList(list,item.getId());});
		return list;
	}
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值