首先創(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í)行的結(jié)果如下:
如下想查詢開發(fā)部的所有上級部門的話上面的遞歸查詢語句簡單改一下就可以了:
執(zhí)行結(jié)果如下:
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 ,不好的同學跟我一起來。
直接語句說明:
好,就這些吧。我是姜友華,下次見。
文章題目:mysql怎么遞歸函數(shù) mysql遞歸sql
當前鏈接:http://chinadenli.net/article46/hipgeg.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供關鍵詞優(yōu)化、域名注冊、企業(yè)網(wǎng)站制作、網(wǎng)站設計公司、商城網(wǎng)站、品牌網(wǎng)站建設
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)