![](https://img-blog.csdnimg.cn/20190411173242297.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3dlaXhpbl80MTk4NjA5Ng==,size_16,color_FFFFFF,t_70)
最近在工作当中,遇见了有ztree关系的查询:
比如:根据父级的部门ID查询所有的子级部门;
根据父级的区划代码查询所属下级的所有区划信息;
根据子级ID查询隶属行政区划信息;
根据组织机构ID查询所有子级组织机构;
数据准备
为了测试,我们首先来创建一张拥有上下级关系的表,这里选择创建一张区划信息表
准备数据:
这里给了一些测试数据,如果需要可以参考:
抓取国家统计局区划数据
可以测试数据:
INSERT INTO `tb_area` VALUES ('1', '中国', '100000', '0');
INSERT INTO `tb_area` VALUES ('2', '广西壮族自治区', '450000000000', '1');
INSERT INTO `tb_area` VALUES ('3', '防城港市', '450600000000', '2');
INSERT INTO `tb_area` VALUES ('4', '港口区', '450602000000', '3');
INSERT INTO `tb_area` VALUES ('5', '防城区', '450603000000', '3');
INSERT INTO `tb_area` VALUES ('6', '上思县', '450621000000', '3');
INSERT INTO `tb_area` VALUES ('7', '东兴市', '450681000000', '3');
INSERT INTO `tb_area` VALUES ('8', '渔州坪街道', '450602001000', '4');
INSERT INTO `tb_area` VALUES ('9', '白沙叶街道', '450602002000', '4');
INSERT INTO `tb_area` VALUES ('10', '沙潭江街道', '450602003000', '4');
INSERT INTO `tb_area` VALUES ('11', '王府街道', '450602004000', '4');
INSERT INTO `tb_area` VALUES ('12', '企沙镇', '450602100000', '4');
INSERT INTO `tb_area` VALUES ('13', '光坡镇', '450602101000', '4');
INSERT INTO `tb_area` VALUES ('14', '水营街道', '450603001000', '5');
INSERT INTO `tb_area` VALUES ('15', '珠河街道', '450603002000', '5');
INSERT INTO `tb_area` VALUES ('109', '文昌街道', '450603003000', '5');
INSERT INTO `tb_area` VALUES ('110', '大菉镇', '450603101000', '5');
INSERT INTO `tb_area` VALUES ('111', '华石镇', '450603102000', '5');
INSERT INTO `tb_area` VALUES ('112', '那梭镇', '450603103000', '5');
INSERT INTO `tb_area` VALUES ('113', '那良镇', '450603104000', '5');
INSERT INTO `tb_area` VALUES ('114', '峒中镇', '450603105000', '5');
INSERT INTO `tb_area` VALUES ('115', '茅岭镇', '450603106000', '5');
INSERT INTO `tb_area` VALUES ('116', '江山镇', '450603107000', '5');
INSERT INTO `tb_area` VALUES ('117', '扶隆镇', '450603108000', '5');
INSERT INTO `tb_area` VALUES ('118', '滩营乡', '450603204000', '5');
INSERT INTO `tb_area` VALUES ('119', '十万山瑶族乡', '450603209000', '5');
INSERT INTO `tb_area` VALUES ('120', '思阳镇', '450621100000', '6');
INSERT INTO `tb_area` VALUES ('121', '在妙镇', '450621101000', '6');
INSERT INTO `tb_area` VALUES ('122', '华兰镇', '450621102000', '6');
INSERT INTO `tb_area` VALUES ('123', '叫安镇', '450621103000', '6');
INSERT INTO `tb_area` VALUES ('124', '南屏瑶族乡', '450621203000', '6');
INSERT INTO `tb_area` VALUES ('125', '平福乡', '450621204000', '6');
INSERT INTO `tb_area` VALUES ('126', '那琴乡', '450621206000', '6');
INSERT INTO `tb_area` VALUES ('127', '公正乡', '450621208000', '6');
INSERT INTO `tb_area` VALUES ('128', '东兴镇', '450681100000', '7');
INSERT INTO `tb_area` VALUES ('129', '江平镇', '450681101000', '7');
INSERT INTO `tb_area` VALUES ('130', '马路镇', '450681102000', '7');
![点击并拖拽以移动](data:image/gif;base64,R0lGODlhAQABAPABAP///wAAACH5BAEKAAAALAAAAAABAAEAAAICRAEAOw==)
代码编写
首先我们来写自下而上的查询:
也就是根据下级区划代码ID查询隶属行政区
创建一个函数:
查询方法:
显示结果:
![](https://img-blog.csdnimg.cn/20190411173144885.png)
也可以直接使用SQL语句:
查出效果相同:
![](https://img-blog.csdnimg.cn/20190411173158866.png)
下来写自上而下的查询:
也就是根据上级区划代码ID查询隶属下级行政区
创建一个函数:
查询方法:
查询结果:
![](https://img-blog.csdnimg.cn/20190411173214723.png)
欢迎关注摘星族,我们首发于微信公众号:
![](https://img-blog.csdnimg.cn/20190411173414171.jpg)
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 用 C# 插值字符串处理器写一个 sscanf
· Java 中堆内存和栈内存上的数据分布和特点
· 开发中对象命名的一点思考
· .NET Core内存结构体系(Windows环境)底层原理浅谈
· C# 深度学习:对抗生成网络(GAN)训练头像生成模型
· 趁着过年的时候手搓了一个低代码框架
· 本地部署DeepSeek后,没有好看的交互界面怎么行!
· 为什么说在企业级应用开发中,后端往往是效率杀手?
· 用 C# 插值字符串处理器写一个 sscanf
· 乌龟冬眠箱湿度监控系统和AI辅助建议功能的实现