java省市区树状实现(递归)

想必看到这篇博客的朋友已经对我接下来要进行描述的知识有了一定的了解,那废话不多说,我们就具体来讲讲如何实现省市区的联查。

最终实现效果:

ae6b509e6c66412c81bfb128e6274828.png

我的项目是Springboot+mybatis-plus,所以请先导入相关依赖哦~

以下是数据库中字段及解释:

9a1eb9ff66c643daa3e45f6e471dc9de.png

接下来,我们需要导入以下依赖:

  <dependency>
            <groupId>cglib</groupId>
            <artifactId>cglib</artifactId>
            <version>3.3.0</version>
        </dependency>

然后是实体类:

@Data
@Builder(toBuilder = true)
@NoArgsConstructor
@AllArgsConstructor
public class City implements Serializable {

  private long id;
  private java.sql.Timestamp createTime;
  private java.sql.Timestamp updateTime;
  private String name;//省或市或区对应的名字
  private String code;//省或市或区对应的编码
  private long level;//省或市或区对应的层级,省对应1,市对应2,区对应3
  private Integer parentId;//父id
  private String acronym;
  private long sort;
  @TableField(exist = false)
  private List<City> children;//非数据库中字段
}

除了最后一个children字段为非数据库字段外,其它均为数据库中字段。

由于我是用代码生成器生成的dao和service的接口和实现,所以这里就不做过多展示了,然后我们进入到controller层:

    public R<List<City>> listRegion() {
//        获取数据库中的所有数据
        List<City> list=cityMapper.selectList(null).stream().map(city-> CglibUtil.copy(city, City.class)).collect(Collectors.toList());
//        根据数据库中的level字段,获取所有level为1的数据并做成一个集合,即获取所有父节点(省)
        List<City> pro=list.stream().filter(civ -> civ.getLevel() == 1).collect(Collectors.toList());
//        根据获取的省的id获取对应省下面的市,然后做成集合
        pro.forEach(oneProvince->{
            List<City> city=list.stream().filter(c->c.getParentId()==oneProvince.getId()).collect(Collectors.toList());
//            根据当前市的id获取相应市下面的区的数据,然后通过collect(Collectors.toList()包装成集合
            city.forEach(oneCity->{
                List<City> town=list.stream().filter(c-> c.getParentId() == oneCity.getId()).collect(Collectors.toList());
                oneCity.setChildren(town);
            });
            oneProvince.setChildren(city);
        });
        return R.Success(pro);
    }

代码中均做有注释,如若仍存在疑问的请留言~

 

  • 11
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

银氨溶液

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值