CTE를 사용하지 않고 MSSQL CTE 쿼리를 MySQL로 변환하려면 어떻게 해야 합니까?

Susan Sarandon
풀어 주다: 2024-11-21 00:37:12
원래의
400명이 탐색했습니다.

How Can I Convert My MSSQL CTE Query to MySQL Without Using CTEs?

MSSQL CTE 쿼리를 MySQL로 변환

주어진 항목에 대해 아래에서 위로 범주 트리를 작성하는 MSSQL의 복잡한 CTE 쿼리가 있습니다. 카테고리 ID. 이 쿼리를 CTE를 지원하지 않는 MySQL로 변환하는 방법을 알고 싶습니다.

MySQL의 제한 사항

안타깝게도 MySQL은 CTE를 지원하지 않습니다. ). 즉, CTE 쿼리를 MySQL로 직접 변환할 수 없습니다.

재귀 저장 프로시저

CTE는 재귀 쿼리를 허용하므로 다음에서 저장 프로시저를 구현해야 합니다. MySQL은 동일한 결과를 얻습니다. 재귀 저장 프로시저는 자체 실행 내에서 자신을 참조할 수 있으므로 계층적 데이터 처리가 가능합니다.

이전 예

이전에 답변한 질문은 재귀 저장 프로시저 구현을 위한 좋은 시작점이 됩니다. MySQL의 저장 프로시저:

  • MySQL의 계층적 데이터에서 깊이 기반 트리 생성 (CTE 없음)

이 답변은 재귀 쿼리를 사용하여 계층적 데이터에서 깊이 기반 트리를 생성하는 저장 프로시저를 만드는 방법을 보여줍니다. 이 접근 방식을 특정 CTE 쿼리에 적용할 수 있습니다.

구현

저장 프로시저의 구체적인 구현은 범주 테이블의 구조와 원하는 출력에 따라 달라집니다. . 그러나 일반적인 단계는 다음과 같습니다.

  1. 필요에 따라 입력 및 출력 매개변수가 포함된 저장 프로시저를 만듭니다.
  2. 저장 프로시저 내에서 재귀 쿼리를 사용하여 다음에서 시작하는 범주 트리를 탐색합니다. 지정된 카테고리 ID.
  3. 재귀 쿼리의 결과를 저장된 카테고리의 출력으로 반환합니다. 프로시저.

이러한 단계를 따르면 MSSQL CTE 쿼리와 유사한 기능을 수행하고 계층적 데이터를 재귀적으로 처리하는 방법을 제공하는 MySQL에서 저장 프로시저를 구현할 수 있습니다.

위 내용은 CTE를 사용하지 않고 MSSQL CTE 쿼리를 MySQL로 변환하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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