国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數據庫技術|

服務器之家 - 數據庫 - Mysql - mysql 遞歸查找菜單節點的所有子節點的方法

mysql 遞歸查找菜單節點的所有子節點的方法

2021-03-10 18:41Rainydayfmb Mysql

這篇文章主要介紹了mysql 遞歸查找菜單節點的所有子節點,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

背景

項目中遇到一個需求,要求查處菜單節點的所有節點,在網上查了一下,大多數的方法用到了存儲過程,由于線上環境不能隨便添加存儲過程,

因此在這里采用類似遞歸的方法對菜單的所有子節點進行查詢。

準備

創建menu表:

?
1
2
3
4
5
6
7
8
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;

插入數據:

?
1
2
3
4
5
6
7
8
9
10
11
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 遞歸查找菜單節點的所有子節點的文章就介紹到這了,更多相關mysql 遞歸查找菜單節點內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!

原文鏈接:https://www.cnblogs.com/rainydayfmb/p/8028868.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国产高清一级片 | 秒播av | 午夜欧美一区二区三区在线播放 | 国产精品久久久久久久久久久免费看 | 国产成人久久 | 美女视频一区二区三区 | 成人黄色在线观看 | 久久99精品久久久久久久 | 日韩欧美视频观看 | 久久久久久久久久久福利观看 | 欧美大片一区二区 | 欧美日韩在线看 | 黄色毛片在线视频 | 网站av | 亚洲视频一区二区三区 | 正在播放国产一区 | 国产精品伊人影院 | 国产欧美精品 | 国产一区二区影院 | 永久免费看黄色 | 日韩欧美一区二区精品 | 欧美在线资源 | 精品伦精品一区二区三区视频 | 国产欧美日韩综合精品一区二区 | 国产成人精品一区二区三区视频 | 欧美日韩精品一区二区三区 | 特黄特黄aaaa级毛片免费看 | 艹逼逼视频 | 久久久久久一区二区三区 | 拍真实国产伦偷精品 | 成人1区2区| 久久亚洲黄色 | 成人片网址 | 国产成人精品a视频一区www | 日韩精品在线免费观看 | 中文字幕第一页在线 | 亚洲免费在线播放 | 亚洲四区| 欧美精品在线视频 | 国产日韩欧美在线 | 国产毛片视频 |