树型结构 构建 工具类

public class RecursionUtil {

    /**
     * 递归查询列表
     *
     * @param allList    总数据
     * @param parentName 上级的key
     * @param parentId   上级的值
     * @param idName     本级ID的key
     * @param returnName 返回的类型 null代表返回对象类型
     * @param <R>        list类型
     * @param <T>        返回类型
     * @return
     */
    public static <R, T> List<T> getChildList(List<R> allList, String parentName, Object parentId, String idName, String returnName) {
        return getChildList(allList, parentName, parentId, idName, returnName, Const.AUTH_DATA_RECURSION_NUM);
    }

    /**
     * 递归查询列表
     *
     * @param allList    总数据
     * @param parentName 上级的key
     * @param parentId   上级的值
     * @param idName     本级ID的key
     * @param returnName 返回的类型,null代表返回对象类型
     * @param depth      最大递归层级
     * @param <R>
     * @param <T>
     * @return
     */
    @SuppressWarnings("unchecked")
    public static <R, T> List<T> getChildList(List<R> allList, String parentName, Object parentId, String idName, String returnName, Integer depth) {
        depth--;
        List<T> arrList = new ArrayList<>();
        if (depth < 0) {
            return arrList;
        }
        for (R r : allList) {
            Map<String, Object> beanMap = BeanUtil.beanToMap(r);
            if (!(beanMap.containsKey(idName) && beanMap.containsKey(parentName))) {
                throw new CrmException(SystemCodeEnum.SYSTEM_NO_SUCH_PARAMENT_ERROR);
            }
            if (Objects.equals(parentId, beanMap.get(parentName))) {
                if (returnName == null) {
                    arrList.add((T) r);
                } else {
                    arrList.add((T) beanMap.get(returnName));
                }
                arrList.addAll(getChildList(allList, parentName, beanMap.get(idName), idName, returnName, depth));
            }
        }
        return arrList;
    }

    /**
     * 递归查询列表数
     *
     * @param allList    总数据
     * @param parentName 上级的key
     * @param parentId   上级的值
     * @param idName     本级ID的key
     * @param treeName   子级树名称
     * @param <R>        list类型
     * @return
     */
    public static <R, T> List<T> getChildListTree(List<R> allList, String parentName, Object parentId, String idName, String treeName, Class<T> clazz) {
        return getChildListTree(allList, parentName, parentId, idName, treeName, clazz, Const.AUTH_DATA_RECURSION_NUM);
    }

    /**
     * 递归查询列表树
     *
     * @param allList    总数据
     * @param parentName 上级的key
     * @param parentId   上级的值
     * @param idName     本级ID的key
     * @param treeName   子级树名称
     * @param depth      最大递归层级
     * @return data
     */

    public static <R, T> List<T> getChildListTree(List<R> allList, String parentName, Object parentId, String idName, String treeName, Class<T> clazz, Integer depth) {
        depth--;
        List<T> arrList = new ArrayList<>();
        if (depth < 0) {
            return arrList;
        }
        for (R data : allList) {
            Map<String, Object> beanMap = BeanUtil.beanToMap(data);
            if (!(beanMap.containsKey(idName) && beanMap.containsKey(parentName))) {
                throw new CrmException(SystemCodeEnum.SYSTEM_NO_SUCH_PARAMENT_ERROR);
            }
            if (Objects.equals(parentId, beanMap.get(parentName))) {
                beanMap.put(treeName, getChildListTree(allList, parentName, beanMap.get(idName), idName, treeName, clazz, depth));
                T toBean = BeanUtil.mapToBean(beanMap, clazz, true);
                arrList.add(toBean);
            }
        }
        return arrList;
    }

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值