메뉴 건너뛰기

?

단축키

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
번호 제목 날짜 조회 수
21 피봇(Pivot)을 이용하여 행(Row)을 열(Column)로 바꾸기 file 2016.12.08 12675
20 숫자 체크 방법 (IS_NUMBER, IS_NUMERIC) file 2016.12.08 23120
19 PL/SQL에서 자바(Java) 클래스(Class), 함수 실행 방법 file 2016.12.08 9384
18 숫자를 문자로 변환 시 소수점 처리 (TO_CHAR, FM) file 2016.12.08 15027
17 여러개(다중) LIKE 검색 방법 (REGEXP_LIKE 함수) file 2016.12.08 12822
16 ROLLUP 합계, 소계 구하기 (GROUP BY) file 2016.12.08 11869
15 컬럼의 값 만큼 행(Row)을 늘리기 file 2016.12.08 14092
14 데이터베이스 백업하기 ( import : 가져오기 , export : 내보내기 ) file 2016.12.08 9882
13 오라클 DB 백업과 복원 2016.12.08 9926
12 오라클 백업 및 복구(Export, Import) file 2016.12.08 9758
11 [Oracle] DB Export, Import 방법 2016.12.08 12607
10 [Oracle] 테이블 스페이스 및 사용자 계정 생성 방법 2016.12.08 8572
9 [Oracle] Rownum을 이용한 페이징 처리 2016.12.08 10385
8 RMAN 을 이용한 오라클 백업 2016.12.08 8582
7 CentOS 6.5 에 Oracle Database 11g Release 2 설치하기 file 2016.12.08 10855
6 오라클 NULL : 값이 존재하지 않는 상태 2017.01.20 7201
5 오라클 ORDER BY : 정렬 2017.01.20 8241
4 오라클] 숫자 체크 방법 (IS_NUMBER, IS_NUMERIC) file 2017.01.20 8620
3 오늘을 기준으로 해당주(week)의 모든 일자조회 2017.01.20 8329
2 오라클 랜덤함수 2018.10.27 2149
Board Pagination Prev 1 2 3 4 5 6 7 Next
/ 7

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

© k2s0o1d4e0s2i1g5n. All Rights Reserved