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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

이 기사는 MySQL의 Alter Table 문을 사용하여 열 추가/드롭 테이블/열 변경 및 열 데이터 유형 변경을 포함하여 테이블을 수정하는 것에 대해 설명합니다.

기사는 인증서 생성 및 확인을 포함하여 MySQL에 대한 SSL/TLS 암호화 구성에 대해 설명합니다. 주요 문제는 자체 서명 인증서의 보안 영향을 사용하는 것입니다. [문자 수 : 159]

기사는 MySQL에서 파티셔닝, 샤딩, 인덱싱 및 쿼리 최적화를 포함하여 대규모 데이터 세트를 처리하기위한 전략에 대해 설명합니다.

기사는 MySQL Workbench 및 Phpmyadmin과 같은 인기있는 MySQL GUI 도구에 대해 논의하여 초보자 및 고급 사용자를위한 기능과 적합성을 비교합니다. [159 자].

이 기사에서는 Drop Table 문을 사용하여 MySQL에서 테이블을 떨어 뜨리는 것에 대해 설명하여 예방 조치와 위험을 강조합니다. 백업 없이는 행동이 돌이킬 수 없으며 복구 방법 및 잠재적 생산 환경 위험을 상세하게합니다.

이 기사에서는 PostgreSQL, MySQL 및 MongoDB와 같은 다양한 데이터베이스에서 JSON 열에서 인덱스를 작성하여 쿼리 성능을 향상시킵니다. 특정 JSON 경로를 인덱싱하는 구문 및 이점을 설명하고 지원되는 데이터베이스 시스템을 나열합니다.

기사는 외국 열쇠를 사용하여 데이터베이스의 관계를 나타내고 모범 사례, 데이터 무결성 및 피할 수있는 일반적인 함정에 중점을 둡니다.

기사는 준비된 명령문, 입력 검증 및 강력한 암호 정책을 사용하여 SQL 주입 및 무차별 적 공격에 대한 MySQL 보안에 대해 논의합니다 (159 자)


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

SublimeText3 영어 버전
권장 사항: Win 버전, 코드 프롬프트 지원!

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

WebStorm Mac 버전
유용한 JavaScript 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

SublimeText3 Linux 새 버전
SublimeText3 Linux 최신 버전

뜨거운 주제



