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 이전에는 재귀 쿼리가 지원되지 않습니다. 다중 레벨 계층 구조에 대한 클라이언트 코드의 재귀를 에뮬레이트하려면 다음 단계를 따르십시오.
위 내용은 계층적 데이터를 검색하기 위해 SQLite3에서 재귀 쿼리를 어떻게 수행할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!