Java Php Mysql 递归查询 查询当前节点下的所有子节点 包含当前节点返回列表
创始人
2024-06-03 15:52:45
0

递归查询

  • MySQL
    • 1. WITH RECURSIVE语法
    • 2. 子查询
    • 3. 函数
  • JAVA代码
    • 执行多次SQL
    • 执行一次SQL
  • PHP代码

MySQL

1. WITH RECURSIVE语法

使用了MySQL的WITH RECURSIVE语法。首先,它选取了当前节点作为起点,然后在递归的过程中找到了所有它的子节点。最后,它输出了所有找到的节点的标识符。
请注意将查询中的[当前节点的ID]替换为你要查询的节点的ID。

WITH RECURSIVE cte AS (SELECT id, parent_idFROM tree_tableWHERE id = [当前节点的ID]UNION ALLSELECT t.id, t.parent_idFROM tree_table tINNER JOIN cte ON t.parent_id = cte.id
)
SELECT id FROM cte;

2. 子查询

如果你使用的MySQL版本不支持WITH RECURSIVE语法,或者你想尝试不使用WITH RECURSIVE的方法;
这个查询使用了两个子查询。第一个子查询选取了当前节点的ID,并且作为递归查询的起点。第二个子查询从tree_table表中自联结,以查找当前节点的所有子节点。然后,使用JOIN操作将这些子节点与tree_table表中的原始记录匹配,从而得到当前节点下的所有子节点。
请注意将查询中的[当前节点的ID]替换为你要查询的节点的ID。

SELECT t1.id
FROM tree_table t1
JOIN (SELECT id FROM tree_table WHERE id = [当前节点的ID]UNION ALLSELECT t2.id FROM tree_table t2 JOIN tree_table t3 ON t2.parent_id = t3.idWHERE t3.id = [当前节点的ID]
) t4
ON t1.id = t4.id;

3. 函数

编写一个存储过程或函数来实现递归查询;将查询中的[当前节点的ID]替换为你要查询的节点的ID。

DELIMITER $$CREATE FUNCTION get_all_children (node_id INT) RETURNS TEXT
BEGINDECLARE child_ids TEXT DEFAULT '';DECLARE child_id INT;SELECT GROUP_CONCAT(id) INTO child_ids FROM tree_table WHERE parent_id = node_id;IF child_ids IS NOT NULL THENSET child_ids = CONCAT(child_ids, ',', get_all_children(child_id));END IF;RETURN child_ids;
END$$DELIMITER ;

这个函数使用递归的方式来查询当前节点下的所有子节点。首先,它查找所有直接子节点的ID,并使用GROUP_CONCAT函数将这些ID连接成一个逗号分隔的字符串。然后,对于每个子节点,函数递归调用自己来查找它的子节点,并将它们的ID也连接到返回值中。最后,函数返回一个包含当前节点下所有子节点ID的逗号分隔字符串。

请注意将函数中的tree_table和id和parent_id字段名称替换为你实际使用的表和字段名称。你可以使用以下语句来调用这个函数:

SELECT get_all_children([当前节点的ID]);

将查询中的[当前节点的ID]替换为你要查询的节点的ID。

JAVA代码

执行多次SQL

这个Java方法使用递归的方式来查询当前节点下的所有子节点。首先,它查询所有直接子节点的ID。然后,对于每个子节点,方法递归调用自己来查找它的子节点。最后,方法返回一个包含当前节点下所有子节点ID的列表。

请注意将示例代码中的tree_table和id和parent_id字段名称替换为你实际使用的表和字段名称,以及将数据库连接的URL、用户名和密码替换为你的实际连接信息。

import java.sql.*;
import java.util.ArrayList;
import java.util.List;public class TreeUtils {public static List getAllChildren(int nodeId, Connection conn) throws SQLException {List childIds = new ArrayList<>();// 查询所有直接子节点PreparedStatement stmt = conn.prepareStatement("SELECT id FROM tree_table WHERE parent_id = ?");stmt.setInt(1, nodeId);ResultSet rs = stmt.executeQuery();// 对于每个子节点,递归调用自己来查找它的子节点while (rs.next()) {int childId = rs.getInt("id");childIds.add(childId);childIds.addAll(getAllChildren(childId, conn));}rs.close();stmt.close();return childIds;}// 使用示例public static void main(String[] args) {Connection conn = null;try {// 创建数据库连接conn = DriverManager.getConnection("jdbc:mysql://localhost/mydatabase", "root", "password");// 查询当前节点的所有子节点List childIds = getAllChildren([当前节点的ID], conn);// 输出所有子节点的IDSystem.out.println(childIds);} catch (SQLException e) {e.printStackTrace();} finally {try {if (conn != null) {conn.close();}} catch (SQLException e) {e.printStackTrace();}}}
}

执行一次SQL

这个Java方法首先执行SQL语句查询所有节点,然后将结果集转换为列表。接着使用递归的方式来查询树结构。它遍历列表中的每个节点,如果节点的父ID等于指定的父ID,则将该节点作为当前节点,递归查询该节点的子节点,并将子节点作为嵌套的子树添加到当前节点。最后,方法返回一个包含根节点的树结构的Map对象。

请注意将示例代码中的tree_table和id和parent_id字段名称替换为你实际使用的表和字段名称,以及将数据库连接的URL、用户名和密码

import java.sql.*;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;public class TreeUtils {public static Map buildTree(List> list, int parentId) {Map node = new HashMap<>();for (Map item : list) {int id = (int) item.get("id");int pid = (int) item.get("parent_id");if (pid == parentId) {// 设置当前节点的属性node.put("id", id);node.put("name", item.get("name"));// 递归查询当前节点的子节点List> children = new ArrayList<>();for (Map child : list) {int childPid = (int) child.get("parent_id");if (childPid == id) {children.add(buildTree(list, id));}}// 如果有子节点,则将子节点添加到当前节点if (!children.isEmpty()) {node.put("children", children);}}}return node;}// 使用示例public static void main(String[] args) {Connection conn = null;try {// 创建数据库连接conn = DriverManager.getConnection("jdbc:mysql://localhost/mydatabase", "root", "password");// 执行SQL语句查询所有节点PreparedStatement stmt = conn.prepareStatement("SELECT * FROM tree_table");ResultSet rs = stmt.executeQuery();// 将结果集转换为列表List> list = new ArrayList<>();while (rs.next()) {Map item = new HashMap<>();item.put("id", rs.getInt("id"));item.put("name", rs.getString("name"));item.put("parent_id", rs.getInt("parent_id"));list.add(item);}// 构建树结构Map tree = buildTree(list, 0);// 输出树结构System.out.println(tree);rs.close();stmt.close();} catch (SQLException e) {e.printStackTrace();} finally {try {if (conn != null) {conn.close();}} catch (SQLException e) {e.printStackTrace();}}}
}

PHP代码

这个PHP函数使用递归的方式来查询当前节点下的所有子节点。首先,它查询所有直接子节点的ID。然后,对于每个子节点,函数递归调用自己来查找它的子节点。最后,函数返回一个包含当前节点下所有子节点ID的数组。

请注意将示例代码中的tree_table和id和parent_id字段名称替换为你实际使用的表和字段名称。如果你使用的是其他语言或框架,可以根据类似的逻辑编写递归函数或方法来实现递归查询。

function get_all_children($node_id, $mysqli) {$child_ids = array();// 查询所有直接子节点$result = $mysqli->query("SELECT id FROM tree_table WHERE parent_id = $node_id");// 对于每个子节点,递归调用自己来查找它的子节点while ($row = $result->fetch_assoc()) {$child_id = $row['id'];$child_ids[] = $child_id;$child_ids = array_merge($child_ids, get_all_children($child_id, $mysqli));}return $child_ids;
}// 使用示例
$mysqli = new mysqli('host', 'username', 'password', 'database');
$node_id = 1; // 替换为你要查询的节点的ID
$child_ids = get_all_children($node_id, $mysqli);
print_r($child_ids);

相关内容

热门资讯

诗词的由来? 诗词的由来?几年前?为啥来?诗歌概念起源 诗歌是一种主情的文学体裁,它以抒情的方式,高度凝练,集中地...
陈梦佳是好人吗? 陈梦佳是好人吗?我不了解TA
关于鹏的成语典故? 关于鹏的成语典故?据一个叫庄周的说这货在水里是鱼名鲲,上了天变成鸟叫鹏,纵横几千里,如垂天之云。据西...
上夜班很困怎么办, 上夜班很困怎么办, 白天多休息。注意饮食营养。晚上上班的时候可以听听节奏比较快的歌,或者听自己一向...
男生不主动找聊天就是没戏吧? 男生不主动找聊天就是没戏吧?你分情况,不同性格的人不一样。比如说处女男,因为天性原因希望女孩子主动一...
说人守时回家的成语 说人守时回家的成语 分秒必争 [fēn miǎo bì zhēng] 生词本基本释义一分一秒也一...
大航海探险物语要在什么辅助脚本... 大航海探险物语要在什么辅助脚本玩呢?大航海探险物语要在鸟人助手上玩呀,这款辅助脚本不用root一样可...
怎样锻炼孩子注意力集中? 怎样锻炼孩子注意力集中?第一,多训练孩子听力,在孩子听某些声音或语言,能听懂其中的细节和主旨。第二,...
本来可爱的小家伙,变成了难管教... 本来可爱的小家伙,变成了难管教的熊孩子,孩子太难管教了怎么办呢?多跟孩子沟通,走进孩子的内心,了解她...
孩子跳舞发圈简单句子 孩子跳舞发圈简单句子1、爸爸妈妈会为你在赛场上的努力而感到骄傲。我们爱你。2、感觉女儿特别的用心,在...
我女朋友和我说她只是喜欢我而不... 我女朋友和我说她只是喜欢我而不爱我,我还怎么办?就是因为你平时对她的宠爱,,让她变成了理所当然,,她...
关于通缉令的问题! 关于通缉令的问题!分级别的。A级才能公布大众的。如果你想曝光此事,可以找当地媒体。。。。
湖南涉外经济学院教师车祸造成 ... 湖南涉外经济学院教师车祸造成 2 人受伤,事故原因是什么?这是因为他们的心情不好的原因,所以,这样的...
微电影创作过程中,工作思路怎么... 微电影创作过程中,工作思路怎么写请问你说的是剧本创作还是拍摄工作,还是整个流程?
求类似异形大战铁血战士这样的把... 求类似异形大战铁血战士这样的把两部不同电影里的人物放到一起对打的电影弗莱迪大战杰森
喜欢看小说的进来 喜欢看小说的进来小说里面都有那些 剑法 轻功 剑名(倚天剑 )门派(专收女弟子的名字要好听的)风云也...
顾瑶周夜深小说叫什么名字? 顾瑶周夜深小说叫什么名字?不是冤家不成婚场景一:“贺尧谦你会有报应的!”某女手握拳头信誓旦旦。“放心...
永恒之塔各种达人(6种),前期... 永恒之塔各种达人(6种),前期中期后期分别做什么东西好卖?永恒之塔各种达人(6种),前期中期后期分别...
用精字组成不同的词语填空 用精字组成不同的词语填空节目( ) 制作( ) 装备( ) 包装( ) ( ...
什么是白富美?什么是高富帅? 什么是白富美?什么是高富帅?白富美就是长得白净、有钱、美丽漂亮,一般形容女的,高富帅是长得个子高,又...