MySQL遞歸查詢樹狀表的子節(jié)點(diǎn)、父節(jié)點(diǎn)具體實(shí)現(xiàn)
更新時(shí)間:2014年03月24日 16:58:42 作者:
本程序?qū)懥藘蓚€(gè)sql存儲(chǔ)過程,子節(jié)點(diǎn)查詢算是照搬了,父節(jié)點(diǎn)查詢是逆思維弄的
簡(jiǎn)介:mysql5.0.94版本,該版本以及較高級(jí)的版本(5.5、6等等)尚未支持循環(huán)遞歸查詢,和sqlserver、oracle相比,mysql難于在樹狀表中層層遍歷的子節(jié)點(diǎn)。本程序重點(diǎn)參考了下面的資料,寫了兩個(gè)sql存儲(chǔ)過程,子節(jié)點(diǎn)查詢算是照搬了,父節(jié)點(diǎn)查詢是逆思維弄的。
表結(jié)構(gòu)和表數(shù)據(jù)就不公示了,查詢的表user_role,主鍵是id,每條記錄有parentid字段(對(duì)應(yīng)該記錄的父節(jié)點(diǎn),當(dāng)然,一個(gè)父節(jié)點(diǎn)自然會(huì)有一個(gè)以上的子節(jié)點(diǎn)嘛)
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ǎn)*/
/*調(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ǎn)*/
/*調(diào)用: 1、select getParentList(6) id; 2、select * From user_role where FIND_IN_SET(id, getParentList(2));*/
弄完了,pm說(shuō)不要弄存儲(chǔ)結(jié)構(gòu),在java里面多查幾次吧。。。存儲(chǔ)結(jié)構(gòu)有很多優(yōu)點(diǎn),包括加快查詢速度、提高安全性等等,但是會(huì)加大數(shù)據(jù)庫(kù)負(fù)荷,很多文章建議結(jié)合使用,個(gè)人也覺得少用點(diǎn)會(huì)好些。
表結(jié)構(gòu)和表數(shù)據(jù)就不公示了,查詢的表user_role,主鍵是id,每條記錄有parentid字段(對(duì)應(yīng)該記錄的父節(jié)點(diǎn),當(dāng)然,一個(gè)父節(jié)點(diǎn)自然會(huì)有一個(gè)以上的子節(jié)點(diǎn)嘛)
復(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ǎn)*/
/*調(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ǎn)*/
/*調(diào)用: 1、select getParentList(6) id; 2、select * From user_role where FIND_IN_SET(id, getParentList(2));*/
弄完了,pm說(shuō)不要弄存儲(chǔ)結(jié)構(gòu),在java里面多查幾次吧。。。存儲(chǔ)結(jié)構(gòu)有很多優(yōu)點(diǎn),包括加快查詢速度、提高安全性等等,但是會(huì)加大數(shù)據(jù)庫(kù)負(fù)荷,很多文章建議結(jié)合使用,個(gè)人也覺得少用點(diǎn)會(huì)好些。
相關(guān)文章
安裝和使用percona-toolkit來(lái)輔助操作MySQL的基本教程
這篇文章主要介紹了安裝和使用percona-toolkit來(lái)輔助操作MySQL的基本教程,這里舉了五個(gè)最常見的命令用法,需要的朋友可以參考下2015-11-11Mysql查詢優(yōu)化之IN子查詢優(yōu)化方法詳解
項(xiàng)目中有需要,使用MySQL的in子查詢,查詢符合in子查詢集合中條件的數(shù)據(jù),但是沒想到的是,MySQL的in子查詢會(huì)如此的慢,讓人無(wú)法接受,下面這篇文章主要給大家介紹了關(guān)于Mysql查詢優(yōu)化之IN子查詢優(yōu)化的相關(guān)資料,需要的朋友可以參考下2023-02-02

Mysql系統(tǒng)變量與狀態(tài)變量詳細(xì)介紹
這篇文章主要介紹了Mysql系統(tǒng)變量與狀態(tài)變量詳細(xì)介紹,能夠在程序運(yùn)行過程中影響Mysql程序行為的變量稱之為系統(tǒng)變量,想了解更多相關(guān)內(nèi)容的小伙伴可以參考下面文章內(nèi)容
2022-09-09 
MySQL如何恢復(fù)單庫(kù)或單表,以及可能遇到的坑
這篇文章主要介紹了MySQL如何恢復(fù)單庫(kù)或單表,以及可能遇到的坑,幫助大家更好的備份數(shù)據(jù)庫(kù),保護(hù)數(shù)據(jù)安全,感興趣的朋友可以了解下
2020-09-09