返回树的方法

private List getTreeDataLoop(long l) {
//返回数据 一级类型,下面挂了子子孙孙类型
List result = new ArrayList<>();
//1 获取所有的类型
List productTypes = productTypeMapper.selectList(null);
//2)遍历所有的类型
Map<Long,ProductType> productTypesDto = new HashMap<>();
for (ProductType productType : productTypes) {
productTypesDto.put(productType.getId(), productType);
}
for (ProductType productType : productTypes) {
Long pid = productType.getPid();
// ①如果没有父亲就是一级类型 放入返回列表中
if (pid.longValue() == 0){
result.add(productType);
}else{
//方案2:通过Map建立id和类型直接关系,以后通过pid直接获取父亲 10+10
ProductType parent = productTypesDto.get(pid);
parent.getChildren().add(productType);
}

}
return result;

}

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值