如何通過sql查找所有父節(jié)點和所有子節(jié)點(以mysql為例)
以圖中的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)文章
MySQL order by與group by查詢優(yōu)化實現(xiàn)詳解
order by 子句盡量使用index方式排序(即using index),避免使用filesort方式排序(即using filesort)。Index方式效率高,它指MySQL掃描索引本身完成排序,filesort則效率低2022-11-11Mysql復制表結(jié)構(gòu)、表數(shù)據(jù)的方法
這篇文章主要介紹了Mysql復制表結(jié)構(gòu)、表數(shù)據(jù)的方法,需要的朋友可以參考下2015-10-10centos7.2下安裝mysql5.7數(shù)據(jù)庫的命令詳解
這篇文章主要介紹了centos7.2下安裝mysql5.7數(shù)據(jù)庫,文中給出了所有的命令,按照命令執(zhí)行就會安裝上 ,需要的朋友可以參考下2019-07-07MySQL中文漢字轉(zhuǎn)拼音的自定義函數(shù)和使用實例(首字的首字母)
這篇文章主要介紹了MySQL中文漢字轉(zhuǎn)拼音的自定義函數(shù)和使用實例,需要的朋友可以參考下2014-06-06