> 데이터 베이스 > MySQL 튜토리얼 > MySQL에서 카테고리 트리를 구축하기 위해 재귀 MSSQL CTE 쿼리를 어떻게 복제할 수 있습니까?

MySQL에서 카테고리 트리를 구축하기 위해 재귀 MSSQL CTE 쿼리를 어떻게 복제할 수 있습니까?

Mary-Kate Olsen
풀어 주다: 2024-12-01 08:54:13
원래의
716명이 탐색했습니다.

How Can I Replicate a Recursive MSSQL CTE Query for Building a Category Tree in MySQL?

MSSQL CTE 쿼리를 MySQL로 변환

id, 상위 ID 및 열이 포함된 '범주' 테이블이 있는 MySQL 스키마에서 이름을 사용하면 지정된 카테고리 ID에 대해 아래에서 위로 카테고리 트리를 작성하는 MSSQL CTE 쿼리를 복제하려고 합니다. 이 쿼리는 다음과 같습니다.

with CTE (id, pid, name)
as
(
    select id, parentid as pid,name
    from category
    where id = 197
      union all
        select CTE.pid as id , category.parentid as pid, category.name
        from CTE
          inner join category
            on category.id = CTE.pid
 )
 select * from CTE 
로그인 후 복사

안타깝게도 MySQL에는 CTE 지원이 부족합니다. 결과적으로 문제의 CTE는 쿼리 내에서 자신을 참조하는 재귀적 CTE이기 때문에 대신 하위 쿼리를 사용하는 것은 옵션이 아닐 수 있습니다. MySQL은 재귀적 CTE를 지원하지 않습니다.

유사한 기능을 얻으려면 저장 프로시저를 구현해야 합니다. "MySQL의 계층적 데이터에서 깊이 기반 트리 생성(CTE 없음)" 방법에 대한 이전 답변은 이러한 절차를 작성하기 위한 출발점이 될 수 있습니다.

위 내용은 MySQL에서 카테고리 트리를 구축하기 위해 재귀 MSSQL CTE 쿼리를 어떻게 복제할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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