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

mysql省市区递归查询_mysql 递归查询1、创建表:DROPTABLEIFEXISTS`t_areainfo`;CREATETABLE`t_areainfo`(`id`int(11)NOT”AUTO_INCREMENT,`level`int(11)DEFAULT”,`name`varchar(255)DEFAULT”,`parentId`int(11)DEFAULT”,`status`i…

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

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);

d4a3f8a29c0c3a9a4aa41899f85a8c2f.png

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

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

e199cffa5acb15e37b778aad23c62f7b.png

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));

ba13d71ec953ceecb41d9a407fe1d9f0.png

包含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.net/147865.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 虚拟机安装centos7网络配置

    虚拟机安装centos7网络配置    在exsi主机上新安装了一台centos7,以下进行配置连接网络。    VmwarevSphere环境下网络标签一定要选择虚拟交换机类型,要不然即使是配置好网卡也连接不到网络如图1所示。如果是平时搭建在本地电脑实验使用的普通VMware软件,注意设置网络桥接,本地电脑网络使用的是无线则选择无线桥接,有线网络则。                …

    2022年5月18日
    34
  • dirsearch使用方法_查看es某个索引下的所有数据

    dirsearch使用方法_查看es某个索引下的所有数据下载地址:https://github.com/maurosoria/dirsearch要求安装并配置好:python3环境,python3环境,python3环境!!!使用方法,在cmd切换到安装目录pydirsearch.py-u网址-e语言(我一般用*)运行结果截图-u指定url-e指定网站语言例如pydirsearch.py-uwww.xxx.com…

    2022年10月6日
    1
  • ubuntu12.04 安装rabbitvcs[通俗易懂]

    ubuntu12.04 安装rabbitvcs[通俗易懂]习惯了在windows下的Tortoisesvn,所以转到ubuntu下面很不习惯命令行的svn。而且,个人感觉如果需要showlog和diff的话都很不爽。今天和一个朋友聊天,他推荐我使用RabbitVCS。类似与Tortoisesvn。安装RabbitVCS的方法步骤如下:1、sudoadd-apt-repositoryppa:rabbitvcs/ppa     #将rab

    2022年7月18日
    17
  • lan8742a_常用以太网PHY芯片DM9161AEP、RTL8201、DP83848CVV、LAN8720A、LAN8742A「建议收藏」

    lan8742a_常用以太网PHY芯片DM9161AEP、RTL8201、DP83848CVV、LAN8720A、LAN8742A「建议收藏」常用的PHY芯片有DM9161AEP、RTL8201、DP83848CVV、LAN8720A、LAN8742A…DM9161AEP、DP83848CVV支持RMII、MII接口,而RTL8201只支持MII接口。拿DM9161AEP举例,可以支持8根通信线(TXD0/TXD1/TXD2/TXD3/RXD0/RXD1/RXD2/RXD3)的MII接口,也可以支持4根通信线(TXD0/TXD1/R…

    2022年6月17日
    77
  • spring cloud和dubbo的区别,各自优缺点「建议收藏」

    spring cloud和dubbo的区别,各自优缺点「建议收藏」区别:————————–来源(背景):Dubbo,是阿里巴巴服务化治理的核心框架,并被广泛应用于阿里巴巴集团的各成员站点。SpringCloud,从命名我们就可以知道,它是SpringSource的产物,Spring社区的强大背书可以说是Java企业界最有影响力的组织了,除了SpringSource之外,还有Pivotal和Netfix是其强大的后盾与技术输…

    2022年6月12日
    34
  • 方法区和常量池_字符串常量池在堆中还是方法区

    方法区和常量池_字符串常量池在堆中还是方法区最近一直被方法区里面存着什么东西困扰着?    1.方法区里存class文件信息和class文件常量池是个什么关系。    2.class文件常量池和运行时常量池是什么关系。         方法区存着类的信息,常量和静态变量,即类被编译后的数据。这个说法其实是没问题的,只是太笼统了。更加详细一点的说法是方法区里存放着类的版本,字段,方法,接口和常量池。

    2025年10月14日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号