> 데이터 베이스 > MySQL 튜토리얼 > 계층적 데이터를 검색하기 위해 SQLite3에서 재귀 쿼리를 어떻게 수행할 수 있습니까?

계층적 데이터를 검색하기 위해 SQLite3에서 재귀 쿼리를 어떻게 수행할 수 있습니까?

Linda Hamilton
풀어 주다: 2024-12-30 13:32:21
원래의
384명이 탐색했습니다.

How Can I Perform Recursive Queries in SQLite3 to Retrieve Hierarchical Data?

SQLite3의 재귀 쿼리

SQLite3에서는 재귀 쿼리를 실행하여 상위-하위가 포함된 테이블에서 계층적 데이터를 검색할 수 있습니다. 주어진 슈퍼파트의 모든 하위파트를 찾는 것과 같은 관계. 이를 달성하려면 SQLite3 버전 3.8.3 이상에서 지원되는 WITH RECURSIVE 구문을 사용할 수 있습니다.

WITH RECURSIVE SubParts AS (
  SELECT Part, SuperPart, 1 AS Level
  FROM Part
  WHERE SuperPart = 'eZ00'
  UNION ALL
  SELECT p.Part, p.SuperPart, s.Level + 1
  FROM Part AS p
  JOIN SubParts AS s ON p.SuperPart = s.Part
)
SELECT * FROM SubParts;
로그인 후 복사

WITH RECURSIVE 문은 원본 행과 행을 포함하는 SubParts라는 임시 테이블을 생성합니다. 상위 행에 대해 1로 초기화되는 Level이라는 열입니다. UNION ALL 절은 현재 행의 하위 부분과 일치하는 행을 선택하고 레벨을 1씩 증가시켜 재귀 단계를 수행합니다. 그런 다음 쿼리는 SubParts 테이블의 모든 행을 반환합니다.

SQLite3 이전 버전 3.8.3

SQLite3 버전 3.8.3 이전에는 재귀 쿼리가 지원되지 않습니다. 다중 레벨 계층 구조에 대한 클라이언트 코드의 재귀를 에뮬레이트하려면 다음 단계를 따르십시오.

  1. 초기 행과 해당 하위 부분을 검색합니다.
  2. 행이 더 이상 없을 때까지 행과 해당 하위 부분을 반복적으로 검색합니다. 돌아왔습니다.

위 내용은 계층적 데이터를 검색하기 위해 SQLite3에서 재귀 쿼리를 어떻게 수행할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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