首先創(chuàng)建一個熟悉的機構表
作為一家“創(chuàng)意+整合+營銷”的成都網(wǎng)站建設機構,我們在業(yè)內(nèi)良好的客戶口碑。創(chuàng)新互聯(lián)提供從前期的網(wǎng)站品牌分析策劃、網(wǎng)站設計、網(wǎng)站制作、做網(wǎng)站、創(chuàng)意表現(xiàn)、網(wǎng)頁制作、系統(tǒng)開發(fā)以及后續(xù)網(wǎng)站營銷運營等一系列服務,幫助企業(yè)打造創(chuàng)新的互聯(lián)網(wǎng)品牌經(jīng)營模式與有效的網(wǎng)絡營銷方法,創(chuàng)造更大的價值。
插入幾條測試數(shù)據(jù):
union all上面的是初始化語句,只會執(zhí)行一次,查到了 開發(fā)部 這一行記錄。
接下來下面的join會用初始化的語句去原來的organization表去join獲取所有 開發(fā)部的子部門 ,然后再用這些 子部門 去join更下面的部門。
執(zhí)行的結果如下:
如下想查詢開發(fā)部的所有上級部門的話上面的遞歸查詢語句簡單改一下就可以了:
執(zhí)行結果如下:
Recursive Common Table Expression 'temp' can contain neither
aggregation nor window functions in recursive query block
mysql
mysql對遞歸的深度是有限制的,默認的遞歸深度是1000。
可以通過 show variables like 'cte_max_recursion_depth'; 進行查看
也可以通過select語句最大執(zhí)行時間對遞歸加以顯示, show variables lile 'max_execution_time';
mysql是可以使用遞歸函數(shù)的,如下例子:
mysql樹查詢,sql遞歸函數(shù)
select cateID from goodscategory where FIND_IN_SET(cateID ,getGoodsChildLst('43242'))
CREATE FUNCTION `getGoodsChildLst`(rootId INT)
RETURNS varchar(1000)
BEGIN
DECLARE sTemp VARCHAR(1000);
DECLARE sTempChd VARCHAR(1000);
SET sTemp = '$';
SET sTempChd =cast(rootId as CHAR);
WHILE sTempChd is not null DO
SET sTemp = concat(sTemp,',',sTempChd);
SELECT group_concat(cateID) INTO sTempChd FROM goodscategory where FIND_IN_SET(parentCateID,sTempChd)0;
END WHILE;
RETURN sTemp;
END
一般比較普遍的就是四種方法:(具體見 SQL Anti-patterns這本書)
因為不支持遞歸查詢,所以Mysql官方當時推薦的是第三種方式:Nested Sets。我是用過的,非常難受。現(xiàn)在支持遞歸查詢,我們可以使用第一種。
其實我還用了一種,一列維持順序,一列維持層級,有空可以把實現(xiàn)寫出來看看。
英文好的朋友請移步到這里: Managing Hierarchical Data in MySQL Using the Adjacency List Model ,不好的同學跟我一起來。
直接語句說明:
好,就這些吧。我是姜友華,下次見。