欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

如何通過sql查找所有父節(jié)點和所有子節(jié)點(以mysql為例)

 更新時間:2023年08月18日 11:47:17   作者:scorpio_meng  
這篇文章主要給大家介紹了關(guān)于如何通過sql查找所有父節(jié)點和所有子節(jié)點,本文以mysql為例,項目中遇到一個需求,要求查處菜單節(jié)點的所有節(jié)點,這里給大家總結(jié)下,需要的朋友可以參考下

以圖中的dept表為例:

  • id:主鍵
  • parent_id:父id
  • name:名稱

1. 獲取所有子節(jié)點sql:

 select id from dept where id = 2
    union
 select t.id
        from (select * from dept where parent_id is not null) t,
             (select @pid := 2) pd
        where FIND_IN_SET(parent_id,@pid) > 0
                  and @pid := CONCAT(@pid,',',id)

此sql查詢id=2的所有子節(jié)點id,并包括當前id=2的節(jié)點,如果不想包括當前節(jié)點,去掉

select id from dept where id = 2
	union

即可

查詢結(jié)果:

2. 獲取所有父節(jié)點sql:

SELECT t2.id
FROM ( SELECT @r AS _id, (SELECT @r := parent_id FROM dept WHERE id = _id) AS parent_id, 
			@l := @l + 1 AS lvl FROM (SELECT @r := 3, @l := 0) vars, dept WHERE @r != 0) t1 
JOIN dept t2 
ON t1._id = t2.id 
ORDER BY t1.lvl DESC

此sql查詢id=3的所有父節(jié)點sql,查詢結(jié)果:

總結(jié) 

到此這篇關(guān)于如何通過sql查找所有父節(jié)點和所有子節(jié)點的文章就介紹到這了,更多相關(guān)sql查找所有父節(jié)點子節(jié)點內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評論