메뉴 건너뛰기

?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄

1. 단일행을 다중 row로 분리

오라클에서 '1,2,3,4,5'라는 문자열을 레코드로 만들려면 어떻게해야 할까?

'1,2,3,4,5'

return
===========
1
2
3
4
5

즉, 결과가 위와같이 나오게 하려면?
connect by를 사용해서 만들수가 있다.

SELECT SUBSTR (str,
                INSTR (str, ',', 1, LEVEL) + 1,
                INSTR (str, ',', 1, LEVEL + 1) - INSTR (str, ',', 1, LEVEL) - 1
                ) sub
  FROM (SELECT ',' || '1,2,3,4,5' || ',' str FROM DUAL)
CONNECT BY LEVEL <= LENGTH (str) - LENGTH (REPLACE (str, ',')) - 1


위와 같이 connect by의 level을 사용해서 구현할 수 있다.
 

2. 다중 row 결과를 단일행으로 연결

이번엔 반대로 해보자.

1
2
3
4
5

return
===========
'1,2,3,4,5'

즉, 이렇게 나오게 하려면 다음과 같이 해보자.

SELECT SUBSTR (MAX (SYS_CONNECT_BY_PATH (str, ',')), 2) path# 
  FROM (
                SELECT str,
                            ROWNUM rnum
                   FROM (
                                SELECT 1 str FROM dual
                                UNION
                                SELECT 2 str FROM dual
                                UNION
                                SELECT 3 str FROM dual
                                UNION
                                SELECT 4 str FROM dual
                                UNION
                                SELECT 5 str FROM dual
                            )
           ) 
START WITH rnum = 1 
CONNECT BY PRIOR rnum = rnum - 1

테이블을 이용해서 같은 결과를 뽑아내려면 다음과 같이 해보자.

SELECT SUBSTR (MAX (SYS_CONNECT_BY_PATH (ename, ',')), 2) path# 
  FROM (
                SELECT ename, ROWNUM rnum 
                       FROM emp
           ) 
START WITH rnum = 1 
CONNECT BY PRIOR rnum = rnum - 1

List of Articles
번호 제목 날짜 조회 수
81 스키마 조회 쿼리 모음 2016.09.12 10036
80 오라클 인스턴스 클라이언트(oracle instant client) 2016.09.12 10980
79 제로보드 reg_date 필드 date 형으로 변환하기 2016.09.12 7168
78 다른 버전의 오라클 import, export 하기 file 2016.09.12 9475
77 DB Link How-To 2016.09.12 7015
76 Create SYNONYM 2016.09.12 7411
75 TOAD에서 Explain Plan 보기 2016.09.12 8230
74 시퀀스 초기화 프로시저 2016.09.12 8924
73 cron을 이용한 Oracle 백업 2016.09.12 8045
72 아카이브 백업 / 복구 2016.09.12 6968
71 Database link, Synonym How to 2016.09.12 7500
70 V$SESSION 테이블 활용 2016.09.12 8119
69 초 이하 단위 시간 얻어오기 2016.09.12 7906
68 PK 수정하기 2016.09.12 7069
67 테이블 생성(다중 PK) 2016.09.12 7936
66 자동증가 SEQUENCE 생성 2016.09.12 7249
65 오라클 암호를 분실한 경우 접속 방법 2016.09.21 7274
64 오라클 웹로직 12.1.3 설치 방법 file 2016.09.21 9902
63 엑셀데이타를 DB 에 저장. Excel => oracle db restore 2016.12.08 8744
62 SQL 작성을 위한 25가지 원칙 2016.12.08 6909
Board Pagination Prev 1 2 3 4 5 6 7 Next
/ 7

하단 정보를 입력할 수 있습니다

© k2s0o1d4e0s2i1g5n. All Rights Reserved