MySql은 어떻게 상위 ID를 사용하여 하위 노드를 아래쪽으로 재귀적으로 쿼리합니까?

王林
풀어 주다: 2023-05-30 16:03:28
앞으로
1158명이 탐색했습니다.

저장 프로시저 작성 필요 없음, 데이터베이스 기능 구축 필요 없음, SQL 일부만 구현 가능

SELECT
	ID.LEVEL,
	DATA.* 
FROM
	(
	SELECT
		@ids AS _ids,
		( SELECT @ids := GROUP_CONCAT( region_id ) FROM region WHERE FIND_IN_SET(parent_id, @ids ) ) AS cids,
		@l := @l + 1 AS LEVEL 
	FROM
		region,
		( SELECT @ids := 3, @l := 0 ) b 
	WHERE
		@ids IS NOT NULL 
	) ID,
	region DATA 
WHERE
	FIND_IN_SET( DATA.region_id, ID._ids ) 
ORDER BY
	LEVEL
로그인 후 복사

MySql은 어떻게 상위 ID를 사용하여 하위 노드를 아래쪽으로 재귀적으로 쿼리합니까?

Test

--创建测试环境
create table t_test(
	id int PRIMARY key,
	parent_id int,
	name varchar(200)
)

insert t_test VALUES(1,null,"中国");

insert t_test VALUES(2,1,"华北");

insert t_test VALUES(3,2,"山西省");
insert t_test VALUES(4,2,"北京");

insert t_test VALUES(5,3,"临汾市");
insert t_test VALUES(6,4,"北京市");


insert t_test VALUES(7,5,"尧都区");
insert t_test VALUES(8,6,"朝阳区");

insert t_test VALUES(9,7,"解放西路");
insert t_test VALUES(10,8,"朝阳北路");


SELECT * FROM t_test;
로그인 후 복사

테스트 데이터 표시

MySql은 어떻게 상위 ID를 사용하여 하위 노드를 아래쪽으로 재귀적으로 쿼리합니까?

쿼리 ID= 1, China Place 아래에 무엇이 있는지 검색

SELECT
	ID.LEVEL,
	DATA.* 
FROM
	(
	SELECT
		@ids AS _ids,
		( SELECT @ids := GROUP_CONCAT( id ) FROM t_test WHERE FIND_IN_SET(parent_id, @ids ) ) AS cids,
		@l := @l + 1 AS LEVEL 
	FROM
		t_test,
		( SELECT @ids := 1, @l := 0 ) b 
	WHERE
		@ids IS NOT NULL 
	) ID,
	t_test DATA 
WHERE
	FIND_IN_SET( DATA.id, ID._ids ) 
ORDER BY
	LEVEL
로그인 후 복사

MySql은 어떻게 상위 ID를 사용하여 하위 노드를 아래쪽으로 재귀적으로 쿼리합니까?

id=3, Shanxi 아래에 있는 장소

SELECT
	ID.LEVEL,
	DATA.* 
FROM
	(
	SELECT
		@ids AS _ids,
		( SELECT @ids := GROUP_CONCAT( id ) FROM t_test WHERE FIND_IN_SET(parent_id, @ids ) ) AS cids,
		@l := @l + 1 AS LEVEL 
	FROM
		t_test,
		( SELECT @ids := 3, @l := 0 ) b 
	WHERE
		@ids IS NOT NULL 
	) ID,
	t_test DATA 
WHERE
	FIND_IN_SET( DATA.id, ID._ids ) 
ORDER BY
	LEVEL
로그인 후 복사

MySql은 어떻게 상위 ID를 사용하여 하위 노드를 아래쪽으로 재귀적으로 쿼리합니까?

id=4, 베이징 아래에 있는 장소 확인

MySql은 어떻게 상위 ID를 사용하여 하위 노드를 아래쪽으로 재귀적으로 쿼리합니까?

마지막으로 아래에서 검색 ID=2

MySql은 어떻게 상위 ID를 사용하여 하위 노드를 아래쪽으로 재귀적으로 쿼리합니까?

인 중국 북부 지역

위 내용은 MySql은 어떻게 상위 ID를 사용하여 하위 노드를 아래쪽으로 재귀적으로 쿼리합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:yisu.com
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿