메뉴 건너뛰기

조회 수 20563 추천 수 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
번호 제목 날짜 조회 수
101 linux oracle 서비스 시작 및 확인 ( 간단 ) 2016.09.11 12296
100 ROLLUP 합계, 소계 구하기 (GROUP BY) file 2016.12.08 11869
99 Oracle SQL Developer 도구 활용하기 - Part1 file 2016.12.08 11740
98 Oracle에서 세자리 콤마 찍기 file 2016.08.29 11720
97 Oracle DBMS_CRYPTO 사용하기 - 암복호화 하기 file 2016.12.08 11610
96 Oracle DB 에서 Toad 를 사용하여 Procedure 디버깅 하기 file 2016.08.30 11427
95 Oracle SQL Developer 도구 활용하기 - Part2 file 2016.12.08 11317
94 실수로 지운 데이터 복구 쿼리 (TIMESTAMP) 2016.12.08 11166
93 SQL 쿼리문 보기 좋게 정렬해주는 사이트 - Instant SQL Formatter file 2016.08.29 10991
92 오라클 인스턴스 클라이언트(oracle instant client) 2016.09.12 10980
91 CentOS 6.5 에 Oracle Database 11g Release 2 설치하기 file 2016.12.08 10855
90 [Oracle 12g] 설치 후 오라클 관리자 계정 접속하기 file 2016.12.08 10721
89 oracle log 보기 - alert, trace 2016.09.11 10650
88 [Oracle] Rownum을 이용한 페이징 처리 2016.12.08 10385
87 oracle 10g - log, trc 관리 정책 스크립트 2016.09.11 10088
86 Toad 사용시 캐릭터 인코더 UTF-8 로 변경하기 file 2016.08.30 10077
85 스키마 조회 쿼리 모음 2016.09.12 10036
84 rownum 사용 - 최근글 몇개만 가져오기 2016.12.08 9984
83 오라클 DB 백업과 복원 2016.12.08 9926
82 오라클 웹로직 12.1.3 설치 방법 file 2016.09.21 9902
Board Pagination Prev 1 2 3 4 5 6 7 Next
/ 7

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

© k2s0o1d4e0s2i1g5n. All Rights Reserved