>데이터 베이스 >MySQL 튜토리얼 >mysql에서 하위 노드를 쿼리하는 방법

mysql에서 하위 노드를 쿼리하는 방법

coldplay.xixi
coldplay.xixi원래의
2020-10-27 15:36:192585검색

Mysql 하위 노드 쿼리 방법: 먼저 메뉴 테이블을 만들고 데이터를 삽입한 다음 명령문을 사용하여 쿼리합니다. 코드는 [select id from(select t1.id,if(find_in_set(parent_id, @pids)) > 0입니다. .. ....)].

mysql에서 하위 노드를 쿼리하는 방법

더 많은 관련 무료 학습 권장 사항: mysql 튜토리얼(동영상)

Mysql 쿼리 하위 노드 방법:

Create 메뉴 테이블: e

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 문 먼저:

select id from (
              select t1.id,
              if(find_in_set(parent_id, @pids) > 0, @pids := concat(@pids, ',', id), 0) as ischild
              from (
                   select id,parent_id from re_menu t where t.status = 1 order by parent_id, id
                  ) t1,
                  (select @pids := 要查询的菜单节点 id) t2
             ) t3 where ischild != 0

, 예를 들어 메뉴 노드 12의 모든 하위 노드를 확인하려면 , 조사 결과는 다음과 같습니다.

mysql에서 하위 노드를 쿼리하는 방법

위 내용은 mysql에서 하위 노드를 쿼리하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.