mysql數(shù)據(jù)庫中怎么利用遞歸查找子節(jié)點-創(chuàng)新互聯(lián)

這期內(nèi)容當中小編將會給大家?guī)碛嘘P(guān)mysql數(shù)據(jù)庫中怎么利用遞歸查找子節(jié)點,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

目前成都創(chuàng)新互聯(lián)已為成百上千家的企業(yè)提供了網(wǎng)站建設(shè)、域名、虛擬空間、綿陽服務(wù)器托管、企業(yè)網(wǎng)站設(shè)計、大方網(wǎng)站維護等服務(wù),公司將堅持客戶導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長,共同發(fā)展。

準備


創(chuàng)建menu表:

CREATE TABLE `menu` (
 `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '菜單id',
 `parent_id` int(11) DEFAULT NULL COMMENT '父節(jié)點id',
 `menu_name` varchar(128) DEFAULT NULL COMMENT '菜單名稱',
 `menu_url` varchar(128) DEFAULT '' COMMENT '菜單路徑',
 `status` tinyint(3) DEFAULT '1' COMMENT '菜單狀態(tài) 1-有效;0-無效',
 PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=12212 DEFAULT CHARSET=utf8;

插入數(shù)據(jù):

INSERT INTO `menu` VALUES ('0', null, '菜單0', ' ', '1');
INSERT INTO `menu` VALUES ('1', '0', '菜單1', '', '1');
INSERT INTO `menu` VALUES ('11', '1', '菜單11', '', '1');
INSERT INTO `menu` VALUES ('12', '1', '菜單12', '', '1');
INSERT INTO `menu` VALUES ('13', '1', '菜單13', '', '1');
INSERT INTO `menu` VALUES ('111', '11', '菜單111', '', '1');
INSERT INTO `menu` VALUES ('121', '12', '菜單121', '', '1');
INSERT INTO `menu` VALUES ('122', '12', '菜單122', '', '1');
INSERT INTO `menu` VALUES ('1221', '122', '菜單1221', '', '1');
INSERT INTO `menu` VALUES ('1222', '122', '菜單1222', '', '1');
INSERT INTO `menu` VALUES ('12211', '1222', '菜單12211', '', '1');

得到的目錄結(jié)構(gòu)如下圖所示:

mysql數(shù)據(jù)庫中怎么利用遞歸查找子節(jié)點

查詢


先貼出sql語句:

比如,要查詢菜單節(jié)點12的所有子節(jié)點,則查處的結(jié)果為:

mysql數(shù)據(jù)庫中怎么利用遞歸查找子節(jié)點

分析


首先分析from后面的語句,根據(jù)parent_id和id 排序,并將要查詢的菜單節(jié)點當做變量,from后面的結(jié)果為

mysql數(shù)據(jù)庫中怎么利用遞歸查找子節(jié)點

接下來看if(express1,express2,express3)條件語句,if語句類似三目運算符,當exprss1成立時,執(zhí)行express2,否則執(zhí)行express3;

FIND_IN_SET(str,strlist),str 要查詢的字符串,strlist 字段名 參數(shù)以”,”分隔 如 (1,2,6,8),查詢字段(strlist)中包含(str)的結(jié)果,返回結(jié)果為null或記錄

如果parent_id 在@pid中,則將@pid 里面再加上parent_id,按行依次執(zhí)行,執(zhí)行過程如下表所示:

mysql數(shù)據(jù)庫中怎么利用遞歸查找子節(jié)點

這時,顯示的id就是菜單id為12的所有子節(jié)點id

上述就是小編為大家分享的mysql數(shù)據(jù)庫中怎么利用遞歸查找子節(jié)點了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

本文題目:mysql數(shù)據(jù)庫中怎么利用遞歸查找子節(jié)點-創(chuàng)新互聯(lián)
網(wǎng)頁網(wǎng)址:http://muchs.cn/article26/ddohjg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供靜態(tài)網(wǎng)站、網(wǎng)站內(nèi)鏈定制開發(fā)、ChatGPT、域名注冊、品牌網(wǎng)站設(shè)計

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(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)站制作