Loading [MathJax]/jax/output/CommonHTML/config.js
首页
学习
活动
专区
圈层
工具
发布
社区首页 >专栏 >mysql省市区递归查询_mysql 递归查询

mysql省市区递归查询_mysql 递归查询

作者头像
全栈程序员站长
发布于 2022-07-02 05:49:53
发布于 2022-07-02 05:49:53
12.7K0
举报

大家好,又见面了,我是你们的朋友全栈君。

1、创建表:

DROP TABLE IF EXISTS `t_areainfo`;

CREATE TABLE `t_areainfo` (

`id` int(11) NOT ” AUTO_INCREMENT,

`level` int(11) DEFAULT ”,

`name` varchar(255) DEFAULT ”,

`parentId` int(11) DEFAULT ”,

`status` int(11) DEFAULT ”,

PRIMARY KEY (`id`)

) ENGINE=InnoDB AUTO_INCREMENT=65 DEFAULT CHARSET=utf8;

2、初始数据:

INSERT INTO `t_areainfo` VALUES (”, ”, ‘中国’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘华北区’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘华南区’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘北京’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘海淀区’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘丰台区’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘朝阳区’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘北京XX区1’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘北京XX区2’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘北京XX区3’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘北京XX区4’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘北京XX区5’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘北京XX区6’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘北京XX区7’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘北京XX区8’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘北京XX区9’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘北京XX区10’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘北京XX区11’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘北京XX区12’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘北京XX区13’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘北京XX区14’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘北京XX区15’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘北京XX区16’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘北京XX区17’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘北京XX区18’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘北京XX区19’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘北京XX区1’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘北京XX区2’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘北京XX区3’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘北京XX区4’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘北京XX区5’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘北京XX区6’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘北京XX区7’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘北京XX区8’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘北京XX区9’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘北京XX区10’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘北京XX区11’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘北京XX区12’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘北京XX区13’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘北京XX区14’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘北京XX区15’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘北京XX区16’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘北京XX区17’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘北京XX区18’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘北京XX区19’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘xx省1’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘xx省2’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘xx省3’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘xx省4’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘xx省5’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘xx省6’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘xx省7’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘xx省8’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘xx省9’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘xx省10’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘xx省11’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘xx省12’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘xx省13’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘xx省14’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘xx省15’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘xx省16’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘xx省17’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘xx省18’, ”, ”);

INSERT INTO `t_areainfo` VALUES (”, ”, ‘xx省19’, ”, ”);

3、向下递归:

利用find_in_set()函数和group_concat()函数实现递归查询:

DROP FUNCTION IF EXISTS queryChildrenAreaInfo;

CREATE FUNCTION queryChildrenAreaInfo(areaId INT)

RETURNS VARCHAR(4000)

BEGIN

DECLARE sTemp VARCHAR(4000);

DECLARE sTempChd VARCHAR(4000);

SET sTemp=’$’;

SET sTempChd = CAST(areaId AS CHAR);

WHILE sTempChd IS NOT NULL DO

SET sTemp= CONCAT(sTemp,’,’,sTempChd);

SELECT GROUP_CONCAT(id) INTO sTempChd FROM t_areainfo WHERE FIND_IN_SET(parentId,sTempChd)>0;

END WHILE;

RETURN sTemp;

END;

4、调用方式:

SELECT queryChildrenAreaInfo(1);

查询id为”4″下面的所有节点

SELECT * FROM t_areainfo WHERE FIND_IN_SET(id,queryChildrenAreaInfo(4));

5、向上递归:

DROP FUNCTION IF EXISTS queryChildrenAreaInfo1;

CREATE FUNCTION queryChildrenAreaInfo1(areaId INT)

RETURNS VARCHAR(4000)

BEGIN

DECLARE sTemp VARCHAR(4000);

DECLARE sTempChd VARCHAR(4000);

SET sTemp=’$’;

SET sTempChd = CAST(areaId AS CHAR);

SET sTemp = CONCAT(sTemp,’,’,sTempChd);

SELECT parentId INTO sTempChd FROM t_areainfo WHERE id = sTempChd;

WHILE sTempChd <> 0 DO

SET sTemp = CONCAT(sTemp,’,’,sTempChd);

SELECT parentId INTO sTempChd FROM t_areainfo WHERE id = sTempChd;

END WHILE;

RETURN sTemp;

END;

6、调用方式:

查询id为”7″的节点的所有上级节点:

SELECT * from t_areainfo where FIND_IN_SET(id,queryChildrenAreaInfo1(7));

包含mysql 递归查询父节点 和子节点

包含mysql 递归查询父节点 和子节点 mysql递归查询,查父集合,查子集合 查子集合 –drop FUNCTION `getChildList` CREATE FUNCTION `getChi …

MySQL递归查询&lowbar;函数语法检查&lowbar;GROUP&lowbar;CONCAT组合结果集的使用

1-前言: 在Mysql使用递归查询是很不方便的,不像Sqlserver可以直接使用声明变量,使用虚拟表等等.如:DECLARE,BEGIN … END ,WHILE ,IF 等等. 在My …

MySQL递归查询树状表的子节点、父节点具体实现

mysql版本(5.5.6等等)尚未支持循环递归查询,和sqlserver.oracle相比,mysql难于在树状表中层层遍历的子节点.本程序重点参考了下面的资料,写了两个sql存储过程,子节点查询算 …

递归的实际业务场景之MySQL 递归查询

喜欢就点个赞呗! 源码

MySQL递归查询

MySQL8.0已经支持CTE递归查询,举例说明 CREATE TABLE EMP (EMPNO integer NOT NULL, ENAME ), JOB ), MGR integer, HIRE …

MySQL递归查询所有子节点,树形结构查询

–表结构 CREATE TABLE `address` ( `id` int(11) NOT NULL AUTO_INCREMENT, `code_value` varchar(32) DEFAUL …

MySQL递归查询树状表的子节点、父节点

表结构和表数据就不公示了,查询的表user_role,主键是id,每条记录有parentid字段; 如下mysql查询函数即可实现根据一个节点查询所有的子节点,根据一个子节点查询所有的父节点.对于数据 …

mysql 递归查询 主要是对于层级关系的查询

最近遇到了一个问题,在mysql中如何完成节点下的所有节点或节点上的所有父节点的查询?在Oracle中我们知道有一个Hierarchical Queries可以通过CONNECT BY来查询,但是,在 …

MySQL递归查询父子节点

1.表结构 CREATE TABLE folder( id BIGINT(20) NOT NULL, parent_id BIGINT(20) DEFAULT NULL, PRIMARY KEY id …

随机推荐

LR录制脚本IE不能打开解决方法

运行环境:win7 64位 解决方法:1.卸载IE11 2.计算机——属性——高级系统设置——性能里的设置——数据执行保护——选择“为除下列选定程序之外的所有程序和服务启用”——添加IE浏览器和VUG …

js设计模式

http://www.csdn.net/article/2011-09-02/303983 阐明JavaScript设计模式.CSDN研发频道对此文进行了整理选取部分内容,供开发者学习.参考. 内容如 …

CountDownLatch和CyclicBarrier的区别(转)

在网上看到很多人对于CountDownLatch和CyclicBarrier的区别简单理解为CountDownLatch是一次性的,而CyclicBarrier在调用reset之后还可以继续使用.那如 …

openssl使用&plus;Demo

1. websiteSSL(secure Socket Layer)TLS(transport Layer Security) – SSL3.0基础之上提出的安全通信标准,目前版本是1.0openss …

A Bug&&num;39&semi;s Life(种类并查集)(也是可以用dfs做)

http://acm.hdu.edu.cn/showproblem.php?pid=1829 A Bug’s Life Time Limit:5000MS Memory Limit:327 …

VSCode插件MSSQL教程(昨天提了一下)

推荐一个跨平台SQL IDE:https://docs.microsoft.com/zh-cn/sql/sql-operations-studio/download 什么数据库都木有(系统自带的不算) …

url全部信息打印

public String findAllContract(HttpServletRequest request,String a){ String string = new StringBuilde …

sublime安装说明

安装Install package https://www.cnblogs.com/lixuwu/p/5693624.html 常用配置 Perference → Settings – User,用下 …

split函数

b=”aa,:bb:c,c”a1,a2,a3=b.split(“:”) #以:为分隔符,分成3个字符串

kbmmw 中虚拟文件操作入门

kbmmw 中一直有一个功能,但是基本上都没有提过,但是在实际应用中,却非常有用,这个功能就是 虚拟文件包功能,他可以把一大堆文件保存到一个文件里面,方便后台管理. kbmmw 的虚拟文件在单元kbm …

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/147865.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
MySQL递归查询 三种实现方式
2.3. 方式三 MySQL 8.0 版本以上 使用 WITH RECURSIVE 实现递归
全栈程序员站长
2022/09/14
12K0
MySQL递归查询 三种实现方式
mysql递归查询
注意:只支持单个查询,意思是不可以根据两个或者两个以上的子节点同时查询出所有父节点。我们可以看到,上面参数都是单个值进行递归查询的。 西面提供一个函数支持多个查询
全栈程序员站长
2022/07/02
3.9K0
mysql递归查询
mysql递归查询方法|mysql递归查询遇到的坑,教你们解决办法
相信很多人都用不惯mysql,小编也是,oracle的递归查询很简单。就一句sql就可以搞定,还有不清楚或者突然忘记需要温习的小伙伴们,大家可以看小编发的以前的关于oracle递归查询的方法,戳这里:【oracle递归查询方法介绍】
小小鱼儿小小林
2020/06/23
1.7K0
同事问我MySQL怎么递归查询,我懵逼了...
最近在做的业务场景涉及到了数据库的递归查询。我们公司用的 Oracle ,众所周知,Oracle 自带有递归查询的功能,所以实现起来特别简单。
烟雨星空
2020/08/04
3.5K0
树形结构!别再用递归实现了,这才是最佳的方案;更快!更强!更好用!
不管你是做前端还是后端的开发,那我相信树形结构的需求一定有遇到过,特别是管理平台类型的项目,一般都会有一个树形结构的菜单栏,再比如说,公司组织架构,层级关系、归属关系等等需求,本质上都是树形结构的一种体现;
一行Java
2022/09/03
15.9K2
树形结构!别再用递归实现了,这才是最佳的方案;更快!更强!更好用!
mysql 层级结构查询
描述:最近遇到了一个问题,在mysql中如何完成节点下的所有节点或节点上的所有父节点的查询? 在Oracle中我们知道有一个Hierarchical Queries可以通过CONNECT BY来查询,但是,在MySQL中还没有对应的函数!!! 下面给出一个function来完成的方法 下面是sql脚本,想要运行的直接赋值粘贴进数据库即可。
用户1217611
2019/05/25
3.4K0
SQLServer CTE 递归查询
在TSQL脚本中,也能实现递归查询,SQL Server提供CTE(Common Table Expression),只需要编写少量的代码,就能实现递归查询,递归查询主要用于层次结构的查询,从叶级(Leaf Level)向顶层(Root Level)查询,或从顶层向叶级查询,或递归的路径(Path)。
挽风
2021/04/13
2.1K0
SQLServer CTE 递归查询
mysql树形结构递归查询
之前一直用的是Oracle,对于树形查询可以使用start with ... connect by 
陈灬大灬海
2018/09/12
9.8K0
mysql树形结构递归查询
MySQL 递归查询实践总结
SELECT id, `name`, parent_id FROM `tb_testcase_suite`
授客
2020/04/10
2.1K0
MySQL 递归查询实践总结
Mysql实现树形递归查询
最近在做项目迁移,Oracle版本的迁到Mysql版本,遇到有些oracle的函数,mysql并没有,所以就只好想自定义函数或者找到替换函数的方法进行改造。
SmileNicky
2019/03/04
5.9K1
【MySQL疑难杂症】如何将树形结构存储在数据库中(方案一 Adjacency List)
弗兰克的猫
2018/01/09
2.3K0
【MySQL疑难杂症】如何将树形结构存储在数据库中(方案一 Adjacency List)
MySQL递归查询_函数语法检查_GROUP_CONCAT组合结果集的使用
在MySL使用递归查询是很不方便的,不像SQL Server可以直接使用声明变量,使用虚拟表等等。如:DECLARE,BEGIN ...  END   ,WHILE ,IF 等等。
星哥玩云
2022/08/17
3.2K0
MySQL递归查询_函数语法检查_GROUP_CONCAT组合结果集的使用
Mysql闭包表之关于国家区域的一个实践
在电商系统中,我们总是会遇到一些树形结构数据的存储需求。如地理区域、位置信息存储,地理信息按照层级划分,会分为很多层级,就拿中国的行政区域划分为例,简单的省-市-县-镇-村就要五个级别。如果系统涉及到跨境的国际贸易,那么存储的地理信息层级会更加深。那么如何正确合理地存储这些数据,并且又能很好的适应各种查询场景就成了我们需要考虑的问题,这次我们来考虑通过闭包表方案,来达到我们的存储及查询需求。
翎野君
2023/05/12
7970
探索MySQL递归查询:处理层次结构数据
在数据库管理中,处理具有层次结构的数据一直是一项常见任务。MySQL的递归查询功能通过公用表表达式(CTE)为处理这类数据提供了便捷的方式。递归查询可以用于管理组织结构、目录树等数据,使您能够轻松地查询任意节点的子节点、父节点或整个路径。
俊才
2024/04/15
2.2K0
探索MySQL递归查询:处理层次结构数据
探索 MySQL 递归查询,优雅的给树结构分页!
递归查询是一种在数据库中处理具有层级结构数据的技术。它通过在查询语句中嵌套引用自身,以实现对嵌套数据的查询。递归查询在处理树状结构、父子关系或层级关系的数据时非常有用。
程序员蜗牛
2024/03/13
1.7K0
探索 MySQL 递归查询,优雅的给树结构分页!
MySQL实现树的遍历
用户1148526
2018/01/03
1.8K0
SQL如何实现MYSQL的递归查询,SQL实现MYSQL递归
所周知,目前的mysql版本中并不支持直接的递归查询,但是通过递归到迭代转化的思路,还是可以在一句SQL内实现树的递归查询的。这个得益于Mysql允许在SQL语句内使用@变量。以下是示例代码。
IT小马哥
2020/03/18
5.8K0
SQL如何求解省市区中的递归问题?
递归是指程序调用自身的一种编程技巧,在SQL中也有递归查询。下面我们通过一个省市区的示例来讲解递归查询的用法。
SQL数据库开发
2024/04/25
3410
SQL如何求解省市区中的递归问题?
【进阶之定义函数】一个查询树结构数据的集合
2.1 统计文章分类的数量,分类是树形结构,所以有一个先查询分类树形的级别的集合。使用的函数包括FIND_IN_SET
用户5640963
2019/10/19
5770
多级部门查询性能问题解决方案
其实,涉及部门层级关系的问题在很多情形下都会遇到,特别是针对toB的应用开发场景。 但奇葩的是,在我们的项目里头,项目经理在前期需求调研时,预估的用户部门最大数为1k,于是相关的开发同事就按照最大数1k*4=4k的目标进行了设计实现,而真正交付到用户生产环境时同步的数据是1w。 What?也就是说,即使之前已经按照最大预估数进行了4倍数放大设计,但是现在是10倍。于是,各种问题接踵而至。 导致该问题出现的原因主要有一下几点:
编程随笔
2019/06/27
1.6K0
多级部门查询性能问题解决方案
相关推荐
MySQL递归查询 三种实现方式
更多 >
领券
社区新版编辑器体验调研
诚挚邀请您参与本次调研,分享您的真实使用感受与建议。您的反馈至关重要,感谢您的支持与参与!
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
首页
学习
活动
专区
圈层
工具
MCP广场
首页
学习
活动
专区
圈层
工具
MCP广场