java后台封装树结构形式数据

本文介绍了一种从数据库加载并展示组织结构数据的方法,通过递归查询子节点,实现了组织结构的层级显示。此外,还展示了如何使用Java Stream API进行数据分组。
  1. 方法为,首先再数据库中查询出所有组织结构的数据,数据格式为List<Map<String,Object>>形式,首先遍历,将顶级节点的数据设置好,然后再以顶级节点的id,数据库查询出的数据,为参数,递归查询子节点,实现代码如下
@RequestMapping("/load/department")
    @ResponseBody
    public String department(Model model) {
        List<Map<String, Object>> listmap = imsCompanyProjectService.orgList();
        List<Map<String, Object>> returnList = new ArrayList<Map<String, Object>>();
        for (Map<String, Object> dataMap : listmap) {
            Map<String, Object> mapArr = new HashMap<String, Object>(16);
            if (dataMap.get("PARENTORGID") == null) {
                mapArr.put("id", dataMap.get("ID"));
                mapArr.put("text", dataMap.get("NAME"));
                mapArr.put("code", dataMap.get("CODE"));
                mapArr.put("data", dataMap.get("NAME"));
                mapArr.put("children", menuChild((String) dataMap.get("ID"), listmap));
                returnList.add(mapArr);
            }
        }
        net.sf.json.JSONArray json = net.sf.json.JSONArray.fromObject(returnList);
        return json.toString();
    }
  /**
     * 递归获取孩子节点
     * @param id
     * @param listmap
     * @return
     */
    private List<Map<String, Object>> menuChild(String id, List<Map<String, Object>> listmap) {
        List<Map<String, Object>> lists = new ArrayList<Map<String, Object>>();
        for (Map<String, Object> dataMap2 : listmap) {
            Map<String, Object> childArray = new HashMap<String, Object>(16);
            if (id.equals(dataMap2.get("PARENTORGID"))) {
                childArray.put("id", dataMap2.get("ID"));
                childArray.put("text", dataMap2.get("NAME"));
                childArray.put("code", dataMap2.get("CODE"));
                childArray.put("data", dataMap2.get("NAME"));
                childArray.put("children", menuChild((String) dataMap2.get("ID"), listmap));
                lists.add(childArray);
            }
        }
        return lists;
    }
  1. 利用 list集合的 groupingBy 分组
 //按parentId 分组
        Map<String, List<NodeDetailDTO>> groupByPidMap = nodeDetailDTOList.stream().collect(Collectors.groupingBy(NodeDetailDTO::getNodeParentId));
   再遍历填充,注意保证是同一个对象。方式是可以先封装到同一个map集合,从集合中get 保证是同一个对象。如:
   Map<String, NodeDetailDecorateDTO> nodeDetailDecorateDTOMap = nodeDetailDTOList.stream().collect(Collectors.toMap(NodeDetailDTO::getNodeId, value -> {
            NodeDetailDecorateDTO dto = new NodeDetailDecorateDTO();
            dto.setNodeId(value.getNodeId());
            return dto;
        }));    
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值