MySQL遞歸查詢樹狀表的子節(jié)點、父節(jié)點具體實現(xiàn)
更新時間:2014年03月24日 16:58:42 作者:
本程序?qū)懥藘蓚€sql存儲過程,子節(jié)點查詢算是照搬了,父節(jié)點查詢是逆思維弄的
簡介:mysql5.0.94版本,該版本以及較高級的版本(5.5、6等等)尚未支持循環(huán)遞歸查詢,和sqlserver、oracle相比,mysql難于在樹狀表中層層遍歷的子節(jié)點。本程序重點參考了下面的資料,寫了兩個sql存儲過程,子節(jié)點查詢算是照搬了,父節(jié)點查詢是逆思維弄的。
表結(jié)構(gòu)和表數(shù)據(jù)就不公示了,查詢的表user_role,主鍵是id,每條記錄有parentid字段(對應(yīng)該記錄的父節(jié)點,當(dāng)然,一個父節(jié)點自然會有一個以上的子節(jié)點嘛)
CREATE FUNCTION `getChildList`(rootId INT)
RETURNS varchar(1000)
BEGIN
DECLARE sChildList VARCHAR(1000);
DECLARE sChildTemp VARCHAR(1000);
SET sChildTemp =cast(rootId as CHAR);
WHILE sChildTemp is not null DO
IF (sChildList is not null) THEN
SET sChildList = concat(sChildList,',',sChildTemp);
ELSE
SET sChildList = concat(sChildTemp);
END IF;
SELECT group_concat(id) INTO sChildTemp FROM user_role where FIND_IN_SET(parentid,sChildTemp)>0;
END WHILE;
RETURN sChildList;
END;
/*獲取子節(jié)點*/
/*調(diào)用: 1、select getChildList(0) id; 2、select * 5From user_role where FIND_IN_SET(id, getChildList(2));*/
CREATE FUNCTION `getParentList`(rootId INT)
RETURNS varchar(1000)
BEGIN
DECLARE sParentList varchar(1000);
DECLARE sParentTemp varchar(1000);
SET sParentTemp =cast(rootId as CHAR);
WHILE sParentTemp is not null DO
IF (sParentList is not null) THEN
SET sParentList = concat(sParentTemp,',',sParentList);
ELSE
SET sParentList = concat(sParentTemp);
END IF;
SELECT group_concat(parentid) INTO sParentTemp FROM user_role where FIND_IN_SET(id,sParentTemp)>0;
END WHILE;
RETURN sParentList;
END;
/*獲取父節(jié)點*/
/*調(diào)用: 1、select getParentList(6) id; 2、select * From user_role where FIND_IN_SET(id, getParentList(2));*/
弄完了,pm說不要弄存儲結(jié)構(gòu),在java里面多查幾次吧。。。存儲結(jié)構(gòu)有很多優(yōu)點,包括加快查詢速度、提高安全性等等,但是會加大數(shù)據(jù)庫負荷,很多文章建議結(jié)合使用,個人也覺得少用點會好些。
表結(jié)構(gòu)和表數(shù)據(jù)就不公示了,查詢的表user_role,主鍵是id,每條記錄有parentid字段(對應(yīng)該記錄的父節(jié)點,當(dāng)然,一個父節(jié)點自然會有一個以上的子節(jié)點嘛)
復(fù)制代碼 代碼如下:
CREATE FUNCTION `getChildList`(rootId INT)
RETURNS varchar(1000)
BEGIN
DECLARE sChildList VARCHAR(1000);
DECLARE sChildTemp VARCHAR(1000);
SET sChildTemp =cast(rootId as CHAR);
WHILE sChildTemp is not null DO
IF (sChildList is not null) THEN
SET sChildList = concat(sChildList,',',sChildTemp);
ELSE
SET sChildList = concat(sChildTemp);
END IF;
SELECT group_concat(id) INTO sChildTemp FROM user_role where FIND_IN_SET(parentid,sChildTemp)>0;
END WHILE;
RETURN sChildList;
END;
/*獲取子節(jié)點*/
/*調(diào)用: 1、select getChildList(0) id; 2、select * 5From user_role where FIND_IN_SET(id, getChildList(2));*/
CREATE FUNCTION `getParentList`(rootId INT)
RETURNS varchar(1000)
BEGIN
DECLARE sParentList varchar(1000);
DECLARE sParentTemp varchar(1000);
SET sParentTemp =cast(rootId as CHAR);
WHILE sParentTemp is not null DO
IF (sParentList is not null) THEN
SET sParentList = concat(sParentTemp,',',sParentList);
ELSE
SET sParentList = concat(sParentTemp);
END IF;
SELECT group_concat(parentid) INTO sParentTemp FROM user_role where FIND_IN_SET(id,sParentTemp)>0;
END WHILE;
RETURN sParentList;
END;
/*獲取父節(jié)點*/
/*調(diào)用: 1、select getParentList(6) id; 2、select * From user_role where FIND_IN_SET(id, getParentList(2));*/
弄完了,pm說不要弄存儲結(jié)構(gòu),在java里面多查幾次吧。。。存儲結(jié)構(gòu)有很多優(yōu)點,包括加快查詢速度、提高安全性等等,但是會加大數(shù)據(jù)庫負荷,很多文章建議結(jié)合使用,個人也覺得少用點會好些。
相關(guān)文章
淺談Mysql時間的存儲?datetime還是時間戳timestamp
本文主要介紹了淺談Mysql時間的存儲?datetime還是時間戳timestamp,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-07-07
MySQL數(shù)據(jù)庫分組查詢group by語句詳解
這篇文章主要介紹了MySQL數(shù)據(jù)庫分組查詢group by語句詳解,文中含有詳細示例代碼說明解析,有需要的朋友可以借鑒參考想=下,希望能夠有所幫助2021-09-09
在Mysql數(shù)據(jù)庫里通過存儲過程實現(xiàn)樹形的遍歷
關(guān)于多級別菜單欄或者權(quán)限系統(tǒng)中部門上下級的樹形遍歷,oracle中有connect by來實現(xiàn),mysql沒有這樣的便捷途徑,所以MySQL遍歷數(shù)據(jù)表是我們經(jīng)常會遇到的頭痛問題,下面給大家介紹在Mysql數(shù)據(jù)庫里通過存儲過程實現(xiàn)樹形的遍歷,一起看看吧2016-11-11
MySQL服務(wù)器登陸故障ERROR 1820 (HY000)的解決方法
這篇文章主要為大家詳細介紹了MySQL服務(wù)器登陸故障的解決方法,幫助大家解決ERROR 1820 (HY000)錯誤,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-10-10

