溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

mysql數據庫中怎么利用遞歸查找子節點

發布時間:2020-11-27 14:04:43 來源:億速云 閱讀:490 作者:Leah 欄目:開發技術

這期內容當中小編將會給大家帶來有關mysql數據庫中怎么利用遞歸查找子節點,文章內容豐富且以專業的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

準備

創建menu表:

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

插入數據:

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');

得到的目錄結構如下圖所示:

mysql數據庫中怎么利用遞歸查找子節點

查詢

先貼出sql語句:

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

mysql數據庫中怎么利用遞歸查找子節點

分析

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

mysql數據庫中怎么利用遞歸查找子節點

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

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

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

mysql數據庫中怎么利用遞歸查找子節點

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

上述就是小編為大家分享的mysql數據庫中怎么利用遞歸查找子節點了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女