[MySQL] RECURSIVE, 재귀적으로 데이터 조회하기 [재귀 쿼리의 활용과 이해]

2024. 3. 12. 17:37·▣ SQL : Database/MySQL🐬
728x90


- RECURSIVE, 재귀적으로 데이터 조회하기

1. RECURSIVE 쿼리란?

RECURSIVE 쿼리는 데이터베이스에서 재귀적으로 데이터를 조회하거나 처리하는 데 사용되는 쿼리다.
주로 계층적 데이터 모델이나 트리 구조와 같은 데이터를 다룰 때 유용하며, 대표적으로 Common Table Expressions (CTE)를 활용하여 구현된다.

- 재귀 쿼리의 활용

  • 계층적 데이터 조회: 조직도, 카테고리 트리 등의 계층적 데이터를 조회할 때 유용
  • 그래프 탐색: 그래프 구조의 데이터를 탐색하고 분석하는 데 활용될 수 있음
  • 계층적 쿼리 연산: 계층적 데이터를 수정하거나 계산할 때 사용될 수 있음

2. 재귀 쿼리의 구성 요소

  • Anchor Member: 재귀를 시작하는 기본 쿼리. 이 쿼리의 결과가 재귀적으로 확장된다.
  • Recursive Member: 재귀적으로 반복되는 쿼리. 자신의 결과를 참조하여 다시 실행된다.
  • Termination Condition: 재귀를 종료하는 조건. 이 조건이 충족될 때까지 재귀가 계속된다.
아래 쿼리는 조직도를 생성하는 재귀 쿼리이다. 초기에는 최상위 매니저를 찾기 위한 기본 쿼리가 실행되고, 그 후 재귀 쿼리가 매니저를 찾아 계속해서 실행된다. (이를 통해 조직도를 계층적으로 조회할 수 있음)
-- Anchor Member: 초기 쿼리 부분, 재귀를 시작하는 지점
-- 최상위 매니저를 찾기 위한 쿼리
WITH RECURSIVE OrgChart AS (
    SELECT employee_id, name, manager_id, 0 AS level
    FROM employees
    WHERE manager_id IS NULL  -- 최상위 매니저는 manager_id가 NULL인 경우
    UNION ALL
    -- Recursive Member: 재귀적으로 반복되는 쿼리 부분
    -- 매니저를 찾아 계속해서 재귀적으로 실행됨
    SELECT e.employee_id, e.name, e.manager_id, oc.level + 1
    FROM employees e
    INNER JOIN OrgChart oc ON e.manager_id = oc.employee_id
)
-- Termination Condition: 재귀를 종료하는 조건은 따로 명시하지 않음
-- 최상위 매니저를 찾고 그 하위 직원을 재귀적으로 계속 조회함
SELECT * FROM OrgChart;

3. 재귀 쿼리 주의사항

  • 성능 문제: 재귀 쿼리는 대량의 데이터에 대해서는 성능 문제를 일으킬 수 있으므로 주의가 필요
  • 루프: 잘못된 재귀 쿼리는 무한 루프에 빠질 수 있으므로 조심해야 함
  • 재귀 깊이 제한: 일부 데이터베이스 시스템은 재귀 쿼리의 최대 깊이를 제한할 수 있음

728x90
'▣ SQL : Database/MySQL🐬' 카테고리의 다른 글
  • [MySQL] root 계정 비밀번호 설정 방법 [root 비밀번호가 invalid일 경우]
  • [MySQL] EXPLAIN을 이해하여 쿼리 성능 최적화하기 [MySQL 인덱스 타는지 확인하는 방법]
  • [MySQL] Access denied for user 'user'@'localhost' [user 계정에 접근 권한이 없습니다]
  • [MySQL] MySQL Test DB 다운로드 방법 [MySQL wolrd DB 다운로드]
예르미(yermi)
예르미(yermi)
끊임없이 제 자신을 계발하는 개발자입니다👨🏻‍💻
  • 예르미(yermi)
    예르미의 코딩노트
    예르미(yermi)
  • 전체
    오늘
    어제
    • 분류 전체보기 (937)
      • ◎ Java (133)
        • Java☕ (93)
        • JSP📋 (26)
        • Applet🧳 (6)
        • Interview👨🏻‍🏫 (8)
      • ◎ JavaScript (48)
        • JavaScript🦎 (25)
        • jQuery🌊 (8)
        • React🌐 (2)
        • Vue.js🔰 (6)
        • Node.js🫒 (3)
        • Google App Script🐑 (4)
      • ◎ HTML5+CSS3 (17)
        • HTML5📝 (8)
        • CSS3🎨 (9)
      • ──────────── (0)
      • ▣ Framework (67)
        • Spring🍃 (36)
        • Spring Boot🍀 (12)
        • Bootstrap💜 (3)
        • Selenium🌕 (6)
        • MyBatis🐣 (10)
      • ▣ Tools (47)
        • API🎯 (18)
        • Library🎲 (15)
        • JitPack🚀 (3)
        • Jenkins👨🏻 (7)
        • Thymeleaf🌿 (4)
      • ▣ Server (32)
        • Apache Tomcat🐱 (14)
        • Apache HTTP Server🛡️ (1)
        • Nginx🧶 (7)
        • OracleXE💿 (4)
        • VisualSVN📡 (4)
      • ▣ OS : 운영체제 (18)
        • cmd : 명령프롬프트💻 (10)
        • Linux🐧 (8)
      • ▣ SQL : Database (56)
        • Oracle SQL🏮 (26)
        • PL SQL💾 (9)
        • MySQL🐬 (6)
        • MariaDB🦦 (6)
        • H2 Database🔠 (3)
        • SQL 실전문제🐌 (6)
      • ────────── (0)
      • ◈ Human Project (86)
        • Mini : Library Service📚 (15)
        • 화면 설계 [HTML]🐯 (10)
        • 서버 프로그램 구현🦁 (15)
        • Team : 여수어때🛫 (19)
        • Custom : Student🏫 (9)
        • Custom : Board📖 (18)
      • ◈ Yermi Project (40)
        • 조사모아(Josa-moa)📬 (5)
        • Riddle-Game🧩 (6)
        • 맛있을 지도🍚 (2)
        • 어디 가! 박대리!🙋🏻‍♂️ (5)
        • 조크베어🐻‍❄️ (4)
        • Looks Like Thirty🦉 (2)
        • Toy Project💎 (12)
        • 오픈소스 파헤치기🪐 (4)
      • ◈ Refactoring (15)
        • Mini : Library Service📚 (8)
        • 서버 프로그램 구현🦁 (1)
        • Team : 여수어때🛫 (0)
        • 쿼리 튜닝일지🔧 (6)
      • ◈ Coding Test (89)
        • 백준(BOJ)👨🏻‍💻 (70)
        • 프로그래머스😎 (2)
        • 코드트리🌳 (7)
        • 알고리즘(Algorithm)🎡 (10)
      • ◈ Study (102)
        • 기초튼튼 개발지식🥔 (25)
        • HTTP 웹 지식💡 (4)
        • 클린코드(Clean Code)🩺 (1)
        • 디자인패턴(GoF)🥞 (12)
        • 다이어그램(Diagram)📈 (4)
        • 파이썬(Python)🐍 (16)
        • 에러노트(Error Note)🧱 (34)
        • 웹 보안(Web Security)🔐 (6)
      • ◈ 공부모임 (39)
        • 혼공학습단⏰ (18)
        • 코드트리 챌린지👊🏻 (2)
        • 개발도서 100독👟 (8)
        • 나는 리뷰어다🌾 (11)
      • ◈ 자격증 공부 (37)
        • 정보처리기사🔱 (16)
        • 정보처리산업기사🔅 (9)
        • 컴퓨터활용능력 1급📼 (12)
      • ─────────── (0)
      • ◐ 기타 (113)
        • 알아두면 좋은 팁(tip)✨ (46)
        • 개발자의 일상🎈 (44)
        • 개발도서 서평🔍 (10)
        • 개발관련 세미나🎤 (2)
        • 블로그 꾸미기🎀 (9)
        • 사도신경 프로젝트🎚️ (2)
  • 인기 글

  • 최근 댓글

  • 태그

    꿀팁
    Project
    BOJ
    코딩 테스트
    SQL
    Java
    CSS
    Error Note
    html
    백준
    javascript
    자바스크립트
    코딩
    spring
    Database
    Oracle
    백준 티어
    프로그래밍
    일상
    jsp
  • 250x250
  • hELLO· Designed By정상우.v4.10.3
예르미(yermi)
[MySQL] RECURSIVE, 재귀적으로 데이터 조회하기 [재귀 쿼리의 활용과 이해]
상단으로

티스토리툴바