国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術(shù)文章
文章詳情頁

mysql 遞歸查找菜單節(jié)點(diǎn)的所有子節(jié)點(diǎn)的方法

瀏覽:12日期:2023-10-08 16:35:52

背景

項(xiàng)目中遇到一個(gè)需求,要求查處菜單節(jié)點(diǎn)的所有節(jié)點(diǎn),在網(wǎng)上查了一下,大多數(shù)的方法用到了存儲(chǔ)過程,由于線上環(huán)境不能隨便添加存儲(chǔ)過程,

因此在這里采用類似遞歸的方法對(duì)菜單的所有子節(jié)點(diǎn)進(jìn)行查詢。

準(zhǔn)備

創(chuàng)建menu表:

CREATE TABLE `menu` ( `id` int(11) NOT NULL AUTO_INCREMENT COMMENT ’菜單id’, `parent_id` int(11) DEFAULT NULL COMMENT ’父節(jié)點(diǎn)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 遞歸查找菜單節(jié)點(diǎn)的所有子節(jié)點(diǎn)的方法

查詢

先貼出sql語句:

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

mysql 遞歸查找菜單節(jié)點(diǎn)的所有子節(jié)點(diǎn)的方法

分析

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

mysql 遞歸查找菜單節(jié)點(diǎn)的所有子節(jié)點(diǎn)的方法

接下來看if(express1,express2,express3)條件語句,if語句類似三目運(yùn)算符,當(dāng)exprss1成立時(shí),執(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 遞歸查找菜單節(jié)點(diǎn)的所有子節(jié)點(diǎn)的方法

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

到此這篇關(guān)于mysql 遞歸查找菜單節(jié)點(diǎn)的所有子節(jié)點(diǎn)的文章就介紹到這了,更多相關(guān)mysql 遞歸查找菜單節(jié)點(diǎn)內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: MySQL 數(shù)據(jù)庫
相關(guān)文章:
主站蜘蛛池模板: 91天堂网| 国产精品特黄一级国产大片 | 九九九九在线视频播放 | 日本毛片在线观看 | 自怕偷自怕亚洲精品 | 一级特色大黄美女播放网站 | 亚洲三级小视频 | 精品小视频在线观看 | 亚洲 自拍 另类 欧美 综合 | 毛片免费观看网址 | 全免费a级毛片免费看不卡 全免费毛片在线播放 | 另类专区另类专区亚洲 | 12至16末成年毛片视频 | 精品视频一二三区 | 国产2021中文天码字幕 | www国产视频| 欧美日韩精品乱国产 | 成人区视频 | 三级黄色在线播放 | 女同日韩互慰互摸在线观看 | 国产精品一区二区三区高清在线 | 成人a毛片久久免费播放 | 草草影院www色极品欧美 | 久精品在线观看 | 久久亚洲不卡一区二区 | 免费看一级欧美毛片视频 | 成年人三级网站 | 99久久综合 | 欧美人与zoxxxx另类9 | 国产男女爽爽爽免费视频 | 免费观看欧美一级毛片 | 中文日韩字幕一区在线观看 | 国产成人精品一区二区免费 | 亚洲一级大片 | 精品国产免费第一区二区三区日韩 | avhd101天天看新片 | 国产一级精品视频 | 国内精品久久久久久影院老狼 | 国产成人亚洲综合无 | 上海一级毛片 | 性欧美videos俄罗斯 |