Mysql 遍历树方法
程序员文章站
2022-05-15 17:59:13
...
Mysql遍历一个节点下面的所有子节点的方法。
在Oracle 中我们知道有一个 Hierarchical Queries 通过CONNECT BY 我们可以方便的查了所有当前节点下的所有子节点。但很遗憾,在MySQL的目前版本中还没有对应的功能。
参考地址:http://blog.csdn.net/ACMAIN_CHM/article/details/4142971
在Oracle 中我们知道有一个 Hierarchical Queries 通过CONNECT BY 我们可以方便的查了所有当前节点下的所有子节点。但很遗憾,在MySQL的目前版本中还没有对应的功能。
参考地址:http://blog.csdn.net/ACMAIN_CHM/article/details/4142971
CREATE DEFINER=`root`@`localhost` FUNCTION `getChildLst`(`rootId` VARCHAR(100)) RETURNS varchar(2000) CHARSET utf8
BEGIN
DECLARE sTemp VARCHAR(1000);
DECLARE sTempChd VARCHAR(1000);
SET sTemp = '$';
SET sTempChd =cast(rootId as CHAR);
WHILE sTempChd is not null DO
SET sTemp = concat(sTemp,',',sTempChd);
SELECT group_concat(id) INTO sTempChd FROM hp_node where FIND_IN_SET(pid,sTempChd)>0;
END WHILE;
RETURN sTemp;
END
Mysql使用方法:SELECT *
FROM hp_node
WHERE FIND_IN_SET( id, getChildLst( 2 ) )
ThinkPHP使用方法:$model = D('Node');
$list = $model->where('FIND_IN_SET( id, getChildLst('.$startId.'))')->select();
AD:真正免费,域名+虚机+企业邮箱=0元
推荐阅读
-
win10下mysql 5.7.23 winx64安装配置方法图文教程
-
mysql5.7.20第一次登录失败的快速解决方法
-
Windows 8下MySQL Community Server 5.6安装配置方法图文教程
-
mysql5.7.20 安装配置方法图文教程(win10)
-
mysql 5.7.21 winx64绿色版安装配置方法图文教程
-
Windows8下mysql 5.6.15 安装配置方法图文教程
-
mysql server 5.7.20 安装配置方法图文教程
-
MySql总弹出mySqlInstallerConsole窗口的解决方法
-
python实现mysql的单引号字符串过滤方法
-
C#中遍历Hashtable的4种方法