>데이터 베이스 >MySQL 튜토리얼 >MySQL 재귀 쿼리는 어떻게 특정 하위 노드의 모든 상위 항목을 효율적으로 검색할 수 있습니까?

MySQL 재귀 쿼리는 어떻게 특정 하위 노드의 모든 상위 항목을 효율적으로 검색할 수 있습니까?

DDD
DDD원래의
2024-12-07 02:20:13846검색

How Can MySQL Recursive Queries Efficiently Retrieve All Ancestors of a Given Child Node?

MySQL의 계층적 쿼리: 상위 관계 검색

계층적 데이터를 효과적으로 관리하기 위해 MySQL은 모든 깊이에서 관계를 탐색할 수 있는 강력한 재귀 쿼리를 제공합니다. . 이는 상위 관계를 추출해야 할 때 특히 유용합니다.

'a'가 상위 필드를 나타내고 'b'가 하위 필드를 나타내는 다음 관계 구조를 고려하십시오.

| a  | b  |
-----------
| 1  | 2  |
| 2  | 3  |
| 3  | 4  |
| 4  | 5  |
| 3  | 6  |
| 4  | 7  |

문제: 주어진 하위 필드 값(예: 5)에 관계없이 모든 상위 필드, 조부모 등을 결정합니다.

해결책:

MySQL은 계층 관계를 효율적으로 탐색할 수 있는 재귀 공통 테이블 표현식(CTE)을 제공합니다.

WITH RECURSIVE Ancestors AS (
    SELECT  *
    FROM    mytable
    WHERE   b = 5
    UNION ALL
    SELECT  t1.*
    FROM    mytable t1
    JOIN    Ancestors t2 ON t1.a = t2.b
)
SELECT  a, b
FROM    Ancestors;

이 쿼리는 각 자녀의 부모를 반복적으로 식별하는 'Ancestors'라는 재귀 CTE를 생성합니다. 계층 구조의 필드입니다. CTE는 값이 5(예: 5)인 하위 필드를 선택하는 것으로 시작됩니다. 그런 다음 'a'(상위) 및 'b'(하위) 필드를 사용하여 'mytable'을 자체적으로 조인합니다. 이 재귀 프로세스는 검색할 상위 필드가 더 이상 없을 때까지 계속됩니다.

마지막 SELECT 문은 '조상' CTE에서 'a'(상위) 및 'b'(하위) 필드를 모두 추출하여 다음을 제공합니다. 원하는 계층적 관계.

이 쿼리가 실행되면 다음 결과가 반환됩니다.

a  | b
-----------
1  | 2
2  | 3
3  | 4
4  | 5

따라서 성공적으로 제공된 하위 필드 값의 부모, 조부모 및 추가 조상을 검색합니다.

위 내용은 MySQL 재귀 쿼리는 어떻게 특정 하위 노드의 모든 상위 항목을 효율적으로 검색할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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