MySQL에서 계층적 하위 데이터 검색: 다단계 재귀 선택
데이터베이스 쿼리 영역에서는 즉각적인 쿼리뿐만 아니라 추출이 필요한 경우가 많습니다. 하위 데이터뿐만 아니라 다단계 하위 정보도 포함됩니다. 이는 특히 조직도나 중첩된 디렉터리 시스템과 같은 계층 구조와 관련이 있습니다.
파일 디렉터리를 모델로 하는 Folder라는 데이터베이스 테이블을 생각해 보세요. 각 폴더에는 고유 ID, 이름 및 선택적 상위 폴더 ID가 있습니다. 우리의 궁극적인 목표는 특정 상위 폴더 ID가 있는 경우 모든 하위 폴더, 하위 하위 폴더 등을 검색하여 포괄적인 계층적 보기를 효과적으로 제공할 수 있는 쿼리를 고안하는 것입니다.
쿼리 분석
제공된 쿼리는 MySQL의 GROUP_CONCAT() 함수를 활용하여 계층적 정보를 집계합니다. 중첩된 SELECT 문을 사용하여 쉼표로 구분된 목록에 해당 ID를 연결하여 모든 하위 폴더를 반복적으로 검색합니다. 그런 다음 이 목록은 변수 lv에 저장되고 추가 하위 수준을 점진적으로 식별하기 위한 필터로 사용됩니다.
가장 바깥쪽 SELECT 문은 단순히 각 반복에 대해 연결된 하위 ID 목록을 그룹화하고 이를 쉼표로 표시합니다. 분리된 문자열. 쿼리는 FIND_IN_SET() 함수를 활용하여 이전에 식별된 하위 ID 집합 내에서 각 하위가 검색되도록 합니다.
실행
예제 데이터세트를 고려하세요.
idFolder | FolderName | idFolderParent |
---|---|---|
1 | ADoc | NULL |
2 | ADoc1 | 7 |
3 | ADoc2 | 2 |
4 | ADoc3 | 3 |
5 | ADoc4 | NULL |
6 | ADoc5 | 5 |
7 | ADoc6 | 5 |
상위 폴더 ID 5에 대한 모든 하위 폴더와 해당 하위 항목을 검색하려면 다음 쿼리를 실행합니다.
<code class="sql">SELECT GROUP_CONCAT(lv SEPARATOR ',') FROM ( SELECT @pv:=(SELECT GROUP_CONCAT(idFolder SEPARATOR ',') FROM Folder WHERE FIND_IN_SET(idFolderParent, @pv)) AS lv FROM Folder JOIN (SELECT @pv:=5) tmp ) a;</code>
결과는 모든 하위 폴더와 해당 하위 항목이 쉼표로 구분된 목록이 됩니다. 하위 하위 ID:
6,7,2,3,4
결론
제공된 쿼리는 MySQL에서 계층적 하위 데이터를 검색하는 강력한 솔루션을 제공하여 폴더 구조와 해당 항목에 대한 포괄적인 보기를 제공합니다. 중첩된 관계. 데이터베이스 구조를 수정하거나 사전 정의된 상위-하위 관계 순서에 의존하지 않고도 계층 구조를 효과적으로 탐색합니다. 이 솔루션은 복잡한 계층적 데이터 구조를 관리하는 데 특히 유용한 것으로 입증되었습니다.
위 내용은 MySQL을 사용하여 계층 구조의 모든 하위 항목을 검색하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!