mysql怎样递归查询所有数据
发表于:2025-01-20 作者:千家信息网编辑
千家信息网最后更新 2025年01月20日,小编给大家分享一下mysql怎样递归查询所有数据,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!mysql递归查询所有数据的
千家信息网最后更新 2025年01月20日mysql怎样递归查询所有数据
小编给大家分享一下mysql怎样递归查询所有数据,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!
mysql递归查询所有数据的方法:首先创建表,并初始数据;然后利用【find_in_set()】函数和【group_concat()】函数实现递归查询,代码为【SELECT queryChildrenAreaInfo(1);】。
mysql递归查询所有数据的方法:
1、创建表
DROP TABLE IF EXISTS `t_areainfo`;CREATE TABLE `t_areainfo` ( `id` int(11) NOT '0' AUTO_INCREMENT, `level` int(11) DEFAULT '0', `name` varchar(255) DEFAULT '0', `parentId` int(11) DEFAULT '0', `status` int(11) DEFAULT '0', PRIMARY KEY (`id`)) ENGINE=InnoDB AUTO_INCREMENT=65 DEFAULT CHARSET=utf8;
2、初始数据
INSERT INTO `t_areainfo` VALUES ('1', '0', '中国', '0', '0');INSERT INTO `t_areainfo` VALUES ('2', '0', '华北区', '1', '0');INSERT INTO `t_areainfo` VALUES ('3', '0', '华南区', '1', '0');INSERT INTO `t_areainfo` VALUES ('4', '0', '北京', '2', '0');INSERT INTO `t_areainfo` VALUES ('5', '0', '海淀区', '4', '0');INSERT INTO `t_areainfo` VALUES ('6', '0', '丰台区', '4', '0');INSERT INTO `t_areainfo` VALUES ('7', '0', '朝阳区', '4', '0');INSERT INTO `t_areainfo` VALUES ('8', '0', '北京XX区1', '4', '0');INSERT INTO `t_areainfo` VALUES ('9', '0', '北京XX区2', '4', '0');INSERT INTO `t_areainfo` VALUES ('10', '0', '北京XX区3', '4', '0');INSERT INTO `t_areainfo` VALUES ('11', '0', '北京XX区4', '4', '0');INSERT INTO `t_areainfo` VALUES ('12', '0', '北京XX区5', '4', '0');INSERT INTO `t_areainfo` VALUES ('13', '0', '北京XX区6', '4', '0');INSERT INTO `t_areainfo` VALUES ('14', '0', '北京XX区7', '4', '0');INSERT INTO `t_areainfo` VALUES ('15', '0', '北京XX区8', '4', '0');INSERT INTO `t_areainfo` VALUES ('16', '0', '北京XX区9', '4', '0');INSERT INTO `t_areainfo` VALUES ('17', '0', '北京XX区10', '4', '0');INSERT INTO `t_areainfo` VALUES ('18', '0', '北京XX区11', '4', '0');INSERT INTO `t_areainfo` VALUES ('19', '0', '北京XX区12', '4', '0');INSERT INTO `t_areainfo` VALUES ('20', '0', '北京XX区13', '4', '0');INSERT INTO `t_areainfo` VALUES ('21', '0', '北京XX区14', '4', '0');INSERT INTO `t_areainfo` VALUES ('22', '0', '北京XX区15', '4', '0');INSERT INTO `t_areainfo` VALUES ('23', '0', '北京XX区16', '4', '0');INSERT INTO `t_areainfo` VALUES ('24', '0', '北京XX区17', '4', '0');INSERT INTO `t_areainfo` VALUES ('25', '0', '北京XX区18', '4', '0');INSERT INTO `t_areainfo` VALUES ('26', '0', '北京XX区19', '4', '0');INSERT INTO `t_areainfo` VALUES ('27', '0', '北京XX区1', '4', '0');INSERT INTO `t_areainfo` VALUES ('28', '0', '北京XX区2', '4', '0');INSERT INTO `t_areainfo` VALUES ('29', '0', '北京XX区3', '4', '0');INSERT INTO `t_areainfo` VALUES ('30', '0', '北京XX区4', '4', '0');INSERT INTO `t_areainfo` VALUES ('31', '0', '北京XX区5', '4', '0');INSERT INTO `t_areainfo` VALUES ('32', '0', '北京XX区6', '4', '0');INSERT INTO `t_areainfo` VALUES ('33', '0', '北京XX区7', '4', '0');INSERT INTO `t_areainfo` VALUES ('34', '0', '北京XX区8', '4', '0');INSERT INTO `t_areainfo` VALUES ('35', '0', '北京XX区9', '4', '0');INSERT INTO `t_areainfo` VALUES ('36', '0', '北京XX区10', '4', '0');INSERT INTO `t_areainfo` VALUES ('37', '0', '北京XX区11', '4', '0');INSERT INTO `t_areainfo` VALUES ('38', '0', '北京XX区12', '4', '0');INSERT INTO `t_areainfo` VALUES ('39', '0', '北京XX区13', '4', '0');INSERT INTO `t_areainfo` VALUES ('40', '0', '北京XX区14', '4', '0');INSERT INTO `t_areainfo` VALUES ('41', '0', '北京XX区15', '4', '0');INSERT INTO `t_areainfo` VALUES ('42', '0', '北京XX区16', '4', '0');INSERT INTO `t_areainfo` VALUES ('43', '0', '北京XX区17', '4', '0');INSERT INTO `t_areainfo` VALUES ('44', '0', '北京XX区18', '4', '0');INSERT INTO `t_areainfo` VALUES ('45', '0', '北京XX区19', '4', '0');INSERT INTO `t_areainfo` VALUES ('46', '0', 'xx省1', '1', '0');INSERT INTO `t_areainfo` VALUES ('47', '0', 'xx省2', '1', '0');INSERT INTO `t_areainfo` VALUES ('48', '0', 'xx省3', '1', '0');INSERT INTO `t_areainfo` VALUES ('49', '0', 'xx省4', '1', '0');INSERT INTO `t_areainfo` VALUES ('50', '0', 'xx省5', '1', '0');INSERT INTO `t_areainfo` VALUES ('51', '0', 'xx省6', '1', '0');INSERT INTO `t_areainfo` VALUES ('52', '0', 'xx省7', '1', '0');INSERT INTO `t_areainfo` VALUES ('53', '0', 'xx省8', '1', '0');INSERT INTO `t_areainfo` VALUES ('54', '0', 'xx省9', '1', '0');INSERT INTO `t_areainfo` VALUES ('55', '0', 'xx省10', '1', '0');INSERT INTO `t_areainfo` VALUES ('56', '0', 'xx省11', '1', '0');INSERT INTO `t_areainfo` VALUES ('57', '0', 'xx省12', '1', '0');INSERT INTO `t_areainfo` VALUES ('58', '0', 'xx省13', '1', '0');INSERT INTO `t_areainfo` VALUES ('59', '0', 'xx省14', '1', '0');INSERT INTO `t_areainfo` VALUES ('60', '0', 'xx省15', '1', '0');INSERT INTO `t_areainfo` VALUES ('61', '0', 'xx省16', '1', '0');INSERT INTO `t_areainfo` VALUES ('62', '0', 'xx省17', '1', '0');INSERT INTO `t_areainfo` VALUES ('63', '0', 'xx省18', '1', '0');INSERT INTO `t_areainfo` VALUES ('64', '0', 'xx省19', '1', '0');
3、向下递归
利用find_in_set()
函数和group_concat()
函数实现递归查询:
DROP FUNCTION IF EXISTS queryChildrenAreaInfo;DELIMITER ;;CREATE FUNCTION queryChildrenAreaInfo(areaId INT)RETURNS VARCHAR(4000)BEGINDECLARE sTemp VARCHAR(4000);DECLARE sTempChd VARCHAR(4000);SET sTemp='$';SET sTempChd = CAST(areaId AS CHAR);WHILE sTempChd IS NOT NULL DOSET 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;;DELIMITER ;
4、调用方式
SELECT queryChildrenAreaInfo(1);
查询id为"4"下面的所有节点
SELECT * FROM t_areainfo WHERE FIND_IN_SET(id,queryChildrenAreaInfo(4));
5、向上递归
DROP FUNCTION IF EXISTS queryChildrenAreaInfo1;DELIMITER;;CREATE FUNCTION queryChildrenAreaInfo1(areaId INT)RETURNS VARCHAR(4000)BEGINDECLARE 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 DOSET sTemp = CONCAT(sTemp,',',sTempChd);SELECT parentId INTO sTempChd FROM t_areainfo WHERE id = sTempChd;END WHILE;RETURN sTemp;END;;DELIMITER ;
6、调用方式
查询id为"7"的节点的所有上级节点:
SELECT * from t_areainfo where FIND_IN_SET(id,queryChildrenAreaInfo1(7));
以上是mysql怎样递归查询所有数据的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注行业资讯频道!
北京
递归
查询
数据
函数
节点
内容
方式
方法
篇文章
上级
不怎么
代码
大部分
更多
知识
行业
资讯
资讯频道
面的
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
海康服务器进入阵列管理
网络安全国家强制标准
储道存储服务器系统
软件开发代码设计过程
工作电信软件开发
excel数据库占内存
手机微信网络安全
数据库表导出到文本文件
网络安全法密码法颁布的顺序
360网络安全密匙是什么
网络安全小报内容小诗
用于建立数据库的
郑州大学软件开发几本
梦易网络技术有限公司
EAP网络安全
时时网络技术有限公司看准网
广州中学生网络安全教育平台
数据库不安全的因素主要有哪些
确保服务器安全流程
网络安全活动周的意义
服务器招副管理员
湖北网络卫星授时服务器云空间
雅安网络技术专业
数据库与软件的
联机游戏需要的服务器
光明大陆服务器人数
网络安全小报视频
深圳多有米网络技术有限公司
字段是数据库表的基本信息单位
湖北教育网络安全测评