메뉴 건너뛰기

조회 수 20566 추천 수 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 TOAD 에서 Edit 를 통해 sql문을 작성할때 참고해야할 View file 2016.08.30 7468
100 oracle listener 로그 형식 - oracle 11g 이전 versioin의 형식으로 변경 2016.09.11 7492
99 Database link, Synonym How to 2016.09.12 7500
98 TOAD 에서 SQL Builder 을 사용하여 DML 문서 작성을 자동화 해본다 file 2016.08.30 7508
97 Merge into를 이용해서 insert나 update를 자동으로 실행하자. 2016.08.29 7572
96 Toad 에서 생성한 테이블의 컬럼위치를 변경하고 싶을 때 Rebuild Table 사용 file 2016.08.30 7604
95 쿼리 파싱 시간 측정 - query parsing time 2016.12.08 7704
94 오라클 25가지 SQL 작성법 2016.12.08 7710
93 오라클(Oracle) SUBSTR 함수로 문자열을 다양하게 자르는 방법 file 2016.08.30 7827
92 초 이하 단위 시간 얻어오기 2016.09.12 7906
91 테이블 생성(다중 PK) 2016.09.12 7936
90 Oracle XDB 리스너 포트 바꾸기 file 2016.08.30 7938
89 오라클 (Oracle) 쿼리 구간별 시간 체크 하기 file 2016.08.30 7974
88 oracle user 관리 2016.09.11 8014
87 오라클(Oracle) 에서 varchar 와 varchar2 의 차이점은 무엇인가 file 2016.08.30 8029
86 오라클(Oracle) 대용량 데이터 토드(Toad)를 이용해서 넣기 file 2016.08.30 8031
85 cron을 이용한 Oracle 백업 2016.09.12 8045
84 Oracle DB 언어셋 설정 2016.09.11 8049
83 날짜관련 계산하기(1) file 2016.12.08 8090
82 V$SESSION 테이블 활용 2016.09.12 8119
Board Pagination Prev 1 2 3 4 5 6 7 Next
/ 7

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

© k2s0o1d4e0s2i1g5n. All Rights Reserved