List数据转换成数状数据

List数据转换成数状数据

1.定义封装树状数据的类

public class AreaTree implements Serializable {
    private Integer id;

    private String name;

    private Integer parentId;

    private String des; 	//描述

    private List<AreaTree> children;

}

2.主要代码

 	//从数据库查询(有分页参数,可去掉)
  	public PageInfo<AreaTree> queryAreaTree(String projectId, Pagination pagination) {
        PageHelper.startPage(pagination.getPage(), pagination.getResults());
        //  从数据库查数据
        List<AreaTree> list = mapper.queryAreaList(projectId);
        List<AreaTree> areaTrees = buildByRecursive(list);
        return new PageInfo<AreaTree>(areaTrees);
    }

    /**
     * 使用递归方法建树
     * @param treeNodes
     * @return
     */
    public static List<AreaTree> buildByRecursive(List<AreaTree> treeNodes) {
        List<AreaTree> trees = new ArrayList<AreaTree>();
        for (AreaTree treeNode : treeNodes) {
            if ("0".equals(treeNode.getParentId().toString())) {
                trees.add(findChildren(treeNode,treeNodes));
            }
        }
        return trees;
    }

    /**
     * 递归查找子节点
     * @param treeNodes
     * @return
     */
    public static AreaTree findChildren(AreaTree treeNode,List<AreaTree> treeNodes) {
        for (AreaTree it : treeNodes) {
            if(treeNode.getId().equals(it.getParentId())) {
                if (treeNode.getChildren() == null) {
                    treeNode.setChildren(new ArrayList<AreaTree>());
                }
                treeNode.getChildren().add(findChildren(it,treeNodes));
            }
        }
        return treeNode;
    }
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值