메뉴 건너뛰기

조회 수 20564 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

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

단축키

Prev이전 문서

Next다음 문서

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

프로그래밍을 할때처럼 오라클 쿼리에서도 Split을 할수 있는 방법을
찾아보니 대부분 함수로 되어있다. 아래는 간단히 쿼리도 해결할수 있다.

아래 예제는 구분자(|)를 기준으로 'A|B|C|D' 를 Split하는 예제이다.

 -- Oracle 10g 이상에서 (정규식 함수사용)
 SELECT distinct regexp_substr(A.TXT, '[^|]+', 1, LEVEL) TXT
   FROM (SELECT 'A|B|C|D' TXT FROM dual) A
CONNECT BY LEVEL <= length(regexp_replace(A.TXT, '[^|]+',''))+1
;
  --Oracle 8i 이상에서
 SELECT substr(A.TXT,
              instr(A.TXT, '|', 1, LEVEL) + 1,
              instr(A.TXT, '|', 1, LEVEL + 1) - instr(A.TXT, '|', 1, LEVEL) - 1) TXT
   FROM (SELECT '|' || 'A|B|C|D' || '|' TXT FROM dual) A
CONNECT BY LEVEL <= length(A.TXT) - length(REPLACE(A.TXT, '|')) - 1

 

 

[응용편]

아래는 위의 쿼리를 응용하여 구분자의 컬럼(Column)을 행(Row)으로 바꾸는 쿼리이다.

 WITH TEMP_TABLE AS (
  SELECT 1 ID, 'A|B|C' TXT FROM DUAL UNION ALL
  SELECT 2 ID, 'B|C'   TXT FROM DUAL UNION ALL
  SELECT 3 ID, 'A|C'   TXT FROM DUAL UNION ALL
  SELECT 4 ID, 'A|B|C' TXT FROM DUAL UNION ALL
  SELECT 5 ID, 'B|C'   TXT FROM DUAL UNION ALL
  SELECT 6 ID, 'B|C|D' TXT FROM DUAL
 )

SELECT A.ID, B.TXT
  FROM TEMP_TABLE A
     , (
        SELECT distinct regexp_substr(AA.TXT, '[^|]+', 1, LEVEL) TXT
          FROM (SELECT replace(wm_concat(distinct AAA.TXT),',','|') TXT
                        FROM TEMP_TABLE AAA) AA
     CONNECT BY LEVEL <= length(regexp_replace(AA.TXT, '[^|]+',''))+1

       ) B
 WHERE instr('|' || A.TXT || '|',  '|' || B.TXT || '|') > 0
 ORDER BY A.ID, B.TXT

 


List of Articles
번호 제목 날짜 조회 수
121 오라클 랜덤함수 2018.10.27 2149
120 오라클 10, 16진수(Decimal, Hex) 변환 2018.10.27 4285
119 Oracle Batch Processing 2016.12.08 6822
118 SQL 작성을 위한 25가지 원칙 2016.12.08 6909
117 아카이브 백업 / 복구 2016.09.12 6968
116 DB Link How-To 2016.09.12 7015
115 oracle 에서 Index를 이용해서 즉 힌트와 rownum을 이용하여 게시판 작성하기 2016.12.08 7023
114 오늘을 기준으로 해당주(week)의 모든 일자조회 2016.12.08 7029
113 PK 수정하기 2016.09.12 7069
112 ORA-28001: the password has expired - 추천 실적용 실전 2016.12.08 7078
111 Oracle 저장 프로시저 샘플 2016.08.29 7140
110 제로보드 reg_date 필드 date 형으로 변환하기 2016.09.12 7168
109 오라클 NULL : 값이 존재하지 않는 상태 2017.01.20 7201
108 오라클(PL/SQL) 미리 정의된 예외처리 2016.12.08 7215
107 자동증가 SEQUENCE 생성 2016.09.12 7249
106 오라클 암호를 분실한 경우 접속 방법 2016.09.21 7274
105 Oracle에서 ORA-28000: 계정이 잠금되었습니다. - 해결 방법 file 2016.08.29 7323
104 기간내 모든 날자(일자) 구하기 2016.12.08 7358
103 Create SYNONYM 2016.09.12 7411
102 Oracle에서 사용자가 생성한 모든 Table, View를 삭제하는 쿼리 만들기 file 2016.08.29 7464
Board Pagination Prev 1 2 3 4 5 6 7 Next
/ 7

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

© k2s0o1d4e0s2i1g5n. All Rights Reserved