树的构建

在开发中,遇到层级关系的数据,要以树状图形式展示出来,之前在网上看的我基本用不了,记录下以java代码构建树形:

import lombok.Getter;
import lombok.Setter;

import java.io.Serializable;
import java.util.ArrayList;
import java.util.List;

@Getter
@Setter
public class Tree<T> implements Serializable {
    private Integer id;
    private String typeName; // 类型名称
    private Integer parentId; // 父id
    private Integer score;  //分数
    private List<Tree<T>>  children; // 子节点
    
    public Tree(Integer id, String typeName, Integer parentId) {
        this.id = id;
        this.typeName = typeName;
        this.parentId = parentId;
    }
    public Tree() {
        super();
    }
}
import java.util.ArrayList;
import java.util.List;

public class BuildTree {
    public static <T> Tree<T> buildNodes(List<Tree<T>> nodes) {
        List<Tree<T>> topNodes = new ArrayList<>();
        if (nodes == null) {
            return null;
        }
        for (Tree<T> children : nodes) {
            Integer pid = children.getParentId();
            if (pid == null || "".equals(pid) || 0 == pid) {
                topNodes.add(children);
                continue;
            }

            for (Tree<T> parent : nodes) {
                Integer id = parent.getId();
                if (id != null && id == pid) {
                    if (parent.getChildren() == null) {
                        parent.setChildren(new ArrayList<>());
                    }
                    parent.getChildren().add(children);
                    continue;
                }
            }

        }
        Tree<T> root = new Tree<T>();
        if (topNodes.size() == 1) {
            root = topNodes.get(0);
        } else {
        	//如果没有顶级节点,就自己定义一个顶级节点
            root.setId(-1);
            root.setChildren(topNodes);
            root.setTypeName("审核阈值配置");
        }
        return root;
    }
}

以下就是将查询出来的数据进行树的构建:

 public HisiResult getAuditType() {
 		//自己定义一个类对象就行
        List<AuditTypeControl> auditTypeList = auditTypeControlMapper.selectAll();
        List<Tree<AuditTypeControl>> trees = new ArrayList<>();
        for (AuditTypeControl auditType : auditTypeList){
            Tree<AuditTypeControl> tree = new Tree<>();
            tree.setId(auditType.getId());
            tree.setParentId(auditType.getParentId());
            tree.setTypeName(auditType.getTypeName());
            tree.setScore(auditType.getScore());
            trees.add(tree);
        }
        Tree<AuditTypeControl> tree =  BuildTree.buildNodes(trees);
        return HisiResult.ok(tree);
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值