[postgreSQL] PostgreSQL 계층형 쿼리 구현 방법

오늘은 계층형 쿼리를 PostgreSQL에서는 어떻게 구현할 수 있는지 정리해 보려 한다.
먼저 오라클에서는 START WITH ~ CONNECT BY PRIOR 를 사용하여 계층형 쿼리를 구현 할수 있다.
PostgreSQL에서는 WITH RECURSIVE 를 제공한다. PostgreSQL로 구현하다 보면 WITH 구문을 많이
사용하여 구현한다는 걸 알 수 있다. 계층형 쿼리 구현에서도 WITH 구문을 사용한다.
오라클에서 구현방식과 PostgreSQL구현 방식을 비교해서 정리하면 다음과 같다.

▶ 오라클

SELECT 컬럼명
FROM 테이블명
START WITH 계층구조 시작 조건(루트 노드 식별)
CONNECT BY PRIOR 계층구조 상하위 조건(부모 자식 노드간의 관계)
SELECT A.CONTS_ID,
             A.CONTS_NM,
             A.UP_CONTS_ID,
             A.MENU_ORD,
             LEVEL   /* 계층구조에서 단계레벨을 나타내주는 함수 */
FROM CLT_MENU A
WHERE A.MENU_INCL_YN = 'Y'
             AND LEVEL IN (2,4)
START WITH A.CONTS_ID = 'voc'   /* 계층구조의 시작조건을 주는 조건절 */
CONNECT BY PRIOR A.CONTS_ID = A.UP_CONTS_ID  /* 계층구조의 상,하위 간의 관계 조건 */
ORDER SIBLINGS BY A.MENU_ORD   /* 계층구조를 유지하면서 정렬해주는 구문 */

▶ PostgreSQL

WITH RECURSIVE  [view ] (보여주고 싶은 컬럼) as (
    
부모쿼리 작성데이터의 시작조건을 구하는 쿼리
    
lUNION ALL 
    계층구조 작성, 하위 데이터를 찾아가기 위한 반복 쿼리
)
view 쿼리
WITH RECURSIVE CODE_LIST(CONTS_ID, CONTS_NM, UP_CONTS_ID, MENU_ORD, DEPTHPATHCYCLEas (
             /* 계층구조의 시작조건 쿼리 */
             SELECT A.CONTS_ID,
                           A.CONTS_NM,  
                           A.UP_CONTS_ID,
                           A.MENU_ORD,
                           1,
                           ARRAY[A.CONTS_ID::text],
                           false
             
FROM CLT_MENU A
             
WHERE A.CONTS_ID = 'voc'
                           
AND A.MENU_INCL_YN = 'Y'
            
 UNION ALL
             /*하위 데이터를 찾아가기 위한 반복조건 쿼리*/
            
 SELECT A.CONTS_ID,
                           A.CONTS_NM,  
                           A.UP_CONTS_ID,
                           A.MENU_ORD,
                           B.DEPTH + 1,
                           ARRAY_APPEND(B.PATH, A.CONTS_ID::text),
                           A.CONTS_ID = any(B.PATH)
             
FROM CLT_MENU A, CODE_LIST B
             
WHERE A.UP_CONTS_ID = B.CONTS_ID
                           
AND A.MENU_INCL_YN = 'Y'
                           
AND NOT CYCLE
)
/*View 쿼리*/

SELECT CONTS_ID,
             CONTS_NM,
             UP_CONTS_ID,
             MENU_ORD,
             DEPTH AS A_MENU_LEVEL,
             PATH

FROM CODE_LIST
WHERE DEPTH IN (2,4)
ORDER BY PATH

- CYCLE RECURSIVE를 통한 재귀 쿼리 수행 시 성능 상의 문제를 해결하기 위함
UNION ALL 다음의 반복조건 쿼리가 수행되면 
CYCLE false이기 때문에 SELECT문이 수행 되고 검색된 자식 node ID 값이 배열(ARRAY[A.CONTS_ID::text])에 추가(ARRAY_APPEND(B.PATH, A.CONTS_ID::text).
- 
ANY(B.PATH) PATH 배열에 자신의 ID값이 있는 지를 검사하여이미 찾은 값에 대해서는 더 이상 데이터 검색을 수행하지 않도록 함.
배열에는 DataType이 int, text인 형태만 담을 수 있으므로 배열에 담을 varchar타입의 컬럼 뒤에 ::text 를 붙여 형태를 변환 해줌.

오라클로 구현할때도 쉽지 않은 계층형 쿼리... 역시 PostgreSQL로 작성하려 해도 쉽지는 않다.
오라클과 달리 WITH RECURSIVE를 이용해서 트리 구조의 계층형 쿼리 구현하는 방법에 대해 정리해
보았다. 다음에 시간되면 데이터를 행에서 열로 전환하는 PIVOT 기능 구현에 대해 정리해 보고자 한다.

오늘 포스팅은 여기까지...

경축! 아무것도 안하여 에스천사게임즈가 새로운 모습으로 재오픈 하였습니다.
어린이용이며, 설치가 필요없는 브라우저 게임입니다.
https://s1004games.com

[출처] https://blog.naver.com/wiseyoun07/221135850258

 

본 웹사이트는 광고를 포함하고 있습니다.
광고 클릭에서 발생하는 수익금은 모두 웹사이트 서버의 유지 및 관리, 그리고 기술 콘텐츠 향상을 위해 쓰여집니다.
번호 제목 글쓴이 날짜 조회 수
공지 오라클 기본 샘플 데이터베이스 졸리운_곰 2014.01.02 28525
공지 [SQL컨셉] 서적 "SQL컨셉"의 샘플 데이타 베이스 SAMPLE DATABASE of ORACLE 가을의 곰을... 2013.02.10 28315
공지 [G_SQL] Sample Database 가을의 곰을... 2012.05.20 35481
1042 [AutoML][AutoKeras] [OSS] AutoKeras로 자동학습(AutoML) 하기 file 졸리운_곰 2023.07.02 211
1041 [NoSQL][MongoDB] Truncate a collection 졸리운_곰 2023.06.04 362
1040 [Tensorflow 2.0] 모델 저장하고 불러오기 졸리운_곰 2023.05.21 271
1039 [pytorch] Pytorch에서 학습한 모델 저장 및 불러오기 졸리운_곰 2023.05.21 296
1038 [MySQL] MySQL - 테이블 만들기 file 졸리운_곰 2023.05.13 346
1037 [R library] library(XML) # install.packages("XML") 인스톨 에러 졸리운_곰 2023.05.06 210
1036 [MySQL] MySQL Strict mode 끄기/켜기 졸리운_곰 2023.05.05 332
1035 [R 데이터 분석] Titanic: Machine Learning from Disaster (타이타닉 생존 예측) file 졸리운_곰 2023.04.29 228
1034 [R 데이터 분석] R 유명한 패키지 정리 졸리운_곰 2023.04.24 351
1033 [NoSQL] MongoDB 인증 모드 (password) 설정 졸리운_곰 2023.03.26 277
1032 [MySQL] [MySQL] 테이블 구조와 데이터 복사 (Table Structure and Data Copy) 졸리운_곰 2023.03.20 237
1031 [R 데이터 분석] Shiny : 대시보드 배포하기 file 졸리운_곰 2023.03.19 268
1030 [데이터 수집 및 전처리] (놀라운) 한글 데이터 짱! AwesomeKorean_Data file 졸리운_곰 2023.03.07 292
1029 [pytorch] Using BERT with Pytorch file 졸리운_곰 2023.03.06 219
1028 [pytorch] Full NMT model from pretrained BERT file 졸리운_곰 2023.03.06 139
1027 [기계학습][딥러닝] PyTorch Hello World 졸리운_곰 2023.02.12 240
1026 [PostgreSQL] 열을 행으로 전환 쿼리 졸리운_곰 2023.01.29 302
» [postgreSQL] PostgreSQL 계층형 쿼리 구현 방법 졸리운_곰 2023.01.29 279
1024 [postgreSQL] ORACLE쿼리에서 postgreSQL쿼리 변환 졸리운_곰 2023.01.29 221
1023 [postgreSQL] [PostgreSQL] stored function(stored procedures) 사용하기 졸리운_곰 2023.01.23 206
대표 김성준 주소 : 경기 용인 분당수지 U타워 등록번호 : 142-07-27414
통신판매업 신고 : 제2012-용인수지-0185호 출판업 신고 : 수지구청 제 123호 개인정보보호최고책임자 : 김성준 sjkim70@stechstar.com
대표전화 : 010-4589-2193 [fax] 02-6280-1294 COPYRIGHT(C) stechstar.com ALL RIGHTS RESERVED