欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

mysql怎么遞歸函數(shù) mysql遞歸sql

mysql中的遞歸調(diào)用

首先創(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是可以使用遞歸函數(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

Mysql8.0遞歸函數(shù)

一般比較普遍的就是四種方法:(具體見 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)

外貿(mào)網(wǎng)站建設