如何通過sql查找所有父節(jié)點(diǎn)和所有子節(jié)點(diǎn)(以mysql為例)
以圖中的dept表為例:
- id:主鍵
- parent_id:父id
- name:名稱
1. 獲取所有子節(jié)點(diǎn)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é)點(diǎn)id,并包括當(dāng)前id=2的節(jié)點(diǎn),如果不想包括當(dāng)前節(jié)點(diǎn),去掉
select id from dept where id = 2 union
即可
查詢結(jié)果:
2. 獲取所有父節(jié)點(diǎn)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é)點(diǎn)sql,查詢結(jié)果:
總結(jié)
到此這篇關(guān)于如何通過sql查找所有父節(jié)點(diǎn)和所有子節(jié)點(diǎn)的文章就介紹到這了,更多相關(guān)sql查找所有父節(jié)點(diǎn)子節(jié)點(diǎn)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
MySQL order by與group by查詢優(yōu)化實(shí)現(xiàn)詳解
order by 子句盡量使用index方式排序(即using index),避免使用filesort方式排序(即using filesort)。Index方式效率高,它指MySQL掃描索引本身完成排序,filesort則效率低2022-11-11mysql刪除關(guān)聯(lián)表的實(shí)操方法
在本篇內(nèi)容里我們給大家整理了關(guān)于mysql刪除關(guān)聯(lián)表的實(shí)操方法以及相關(guān)SQL語句,需要的朋友們學(xué)習(xí)下吧。2019-05-05Mysql復(fù)制表結(jié)構(gòu)、表數(shù)據(jù)的方法
這篇文章主要介紹了Mysql復(fù)制表結(jié)構(gòu)、表數(shù)據(jù)的方法,需要的朋友可以參考下2015-10-10centos7.2下安裝mysql5.7數(shù)據(jù)庫的命令詳解
這篇文章主要介紹了centos7.2下安裝mysql5.7數(shù)據(jù)庫,文中給出了所有的命令,按照命令執(zhí)行就會(huì)安裝上 ,需要的朋友可以參考下2019-07-07MySQL中文漢字轉(zhuǎn)拼音的自定義函數(shù)和使用實(shí)例(首字的首字母)
這篇文章主要介紹了MySQL中文漢字轉(zhuǎn)拼音的自定義函數(shù)和使用實(shí)例,需要的朋友可以參考下2014-06-06