>데이터 베이스 >MySQL 튜토리얼 >SQLite3에서 재귀 쿼리를 어떻게 수행할 수 있나요?

SQLite3에서 재귀 쿼리를 어떻게 수행할 수 있나요?

DDD
DDD원래의
2024-12-31 10:57:10605검색

How Can I Perform Recursive Queries in SQLite3?

SQLite3의 재귀 쿼리: 종합 가이드

SQLite3은 역사적으로 재귀 쿼리에 대한 지원이 부족했지만 최근 발전을 통해 이 기능이 도입되었습니다. 버전에 CTE(공통 테이블 표현식) 도입 3.8.3.

재귀 CTE 사용(SQLite 3.8.3 이상)

SQLite3은 이제 재귀 CTE 정의를 허용하는 WITH 문을 제공합니다. 재귀 CTE를 사용하면 재귀 쿼리를 쉽게 수행할 수 있습니다.

WITH RECURSIVE Subparts AS (
    SELECT Part, SuperPart
    FROM Part
    WHERE SuperPart IS NULL
    UNION
    SELECT Part, SuperPart
    FROM Subparts
    JOIN Part
    ON Subparts.SuperPart = Part.Part
)
SELECT *
FROM Subparts;

이전 SQLite3 버전의 재귀 쿼리

버전 3.8.3 이전에는 SQLite3에서 지원하지 않았습니다. 재귀 쿼리. 그러나 클라이언트 코드에서 재귀를 구현하면 해결 방법이 있습니다.

  1. 초기 단계: 초기 행과 하위 파트 ID를 검색합니다.
SELECT Part, SuperPart
FROM Part
WHERE SuperPart IS NULL;
  1. 재귀 단계: 하위 부품에 대한 행 및 하위 부품 ID를 재귀적으로 검색합니다.
SELECT Part, SuperPart
FROM Part
WHERE SuperPart IN (sub-part IDs from previous step);
  1. 중지 조건: 더 이상 하위 부품이 발견되지 않을 때까지 재귀를 계속합니다.

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

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