濮阳杆衣贸易有限公司

主頁(yè) > 知識(shí)庫(kù) > mysql 遞歸查找菜單節(jié)點(diǎn)的所有子節(jié)點(diǎn)的方法

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

熱門標(biāo)簽:房產(chǎn)智能外呼系統(tǒng)品牌 400電話鄭州申請(qǐng) 沃克斯電梯外呼線路圖 云南語(yǔ)音外呼系統(tǒng)平臺(tái) 天智外呼系統(tǒng) 常州電銷外呼系統(tǒng)一般多少錢 北京人工外呼系統(tǒng)價(jià)錢 地圖標(biāo)注被騙三百怎么辦 福州呼叫中心外呼系統(tǒng)哪家好

背景

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

因此在這里采用類似遞歸的方法對(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-無(wú)效',
 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)如下圖所示:

查詢

先貼出sql語(yǔ)句:

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

分析

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

接下來(lái)看if(express1,express2,express3)條件語(yǔ)句,if語(yǔ)句類似三目運(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í)行過(guò)程如下表所示:

這時(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)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • Mysql臟頁(yè)flush及收縮表空間原理解析
  • 推薦幾款MySQL相關(guān)工具
  • 淺析MySQL的lru鏈表
  • MySQL的查詢緩存和Buffer Pool
  • 淺析MySQL的基數(shù)統(tǒng)計(jì)
  • MySQL的表空間是什么
  • MySQL慢查詢?nèi)绾味ㄎ辉斀?/li>
  • MySQL的Flush-List和臟頁(yè)的落盤機(jī)制

標(biāo)簽:移動(dòng) 鹽城 珠海 徐州 沈陽(yáng) 沈陽(yáng) 黔東 拉薩

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《mysql 遞歸查找菜單節(jié)點(diǎn)的所有子節(jié)點(diǎn)的方法》,本文關(guān)鍵詞  mysql,遞歸,查找,菜單,節(jié)點(diǎn),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《mysql 遞歸查找菜單節(jié)點(diǎn)的所有子節(jié)點(diǎn)的方法》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于mysql 遞歸查找菜單節(jié)點(diǎn)的所有子節(jié)點(diǎn)的方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    汉寿县| 郁南县| 林州市| 镇巴县| 西盟| 轮台县| 梨树县| 北海市| 元江| 江西省| 宁蒗| 凤山县| 呼和浩特市| 泸溪县| 平顶山市| 房产| 太仓市| 红原县| 天峨县| 涿州市| 安塞县| 寿宁县| 滨海县| 南投市| 汕尾市| 资溪县| 富源县| 镇坪县| 常州市| 和林格尔县| 庄河市| 葫芦岛市| 福清市| 友谊县| 辉县市| 海门市| 茶陵县| 保德县| 安溪县| 涿鹿县| 广汉市|