메뉴 건너뛰기

?

단축키

Prev이전 문서

Next다음 문서

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

단축키

Prev이전 문서

Next다음 문서

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

WM_CONCAT 함수를 이용하여 손쉽게 여러행의 데이터를 한 컬럼으로 합칠 수 있다.

 방법 1. (WM_CONCAT 이용)

--가상 테이블
WITH TEST_TABLE AS (
    SELECT '고구려' COUNTRY, '1대' ST, '동명성왕'   KING_NM FROM DUAL UNION ALL
    SELECT '고구려' COUNTRY, '3대' ST, '대무신왕'   KING_NM FROM DUAL UNION ALL
    SELECT '백제'   COUNTRY, '1대' ST, '온조왕'     KING_NM FROM DUAL UNION ALL
    SELECT '고구려' COUNTRY, '2대' ST, '유리왕'     KING_NM FROM DUAL UNION ALL
    SELECT '백제'   COUNTRY, '3대' ST, '기루왕'     KING_NM FROM DUAL UNION ALL
    SELECT '신라'   COUNTRY, '1대' ST, '남해왕'     KING_NM FROM DUAL UNION ALL
    SELECT '신라'   COUNTRY, '1대' ST, '박혁거세'   KING_NM FROM DUAL UNION ALL
    SELECT '백제'   COUNTRY, '2대' ST, '다루왕'     KING_NM FROM DUAL UNION ALL
    SELECT '신라'   COUNTRY, '1대' ST, '유리이사금' KING_NM FROM DUAL
)

--조회 쿼리
SELECT COUNTRY
     , WM_CONCAT(KING_NM) KING_NM
  FROM TEST_TABLE
 GROUP BY COUNTRY

- WM_CONCAT  함수를 이용하여 여러행의 값을 하나의 컬럼으로 합칠 수 있다.

값의 구분은 쉼표(,)로 구분되어 합쳐진다.

 

□ 방법 2. (XMLAGG, XMLELEMENT 이용)

--가상 테이블
WITH TEST_TABLE AS (
    SELECT '고구려' COUNTRY, '1대' ST, '동명성왕'   KING_NM FROM DUAL UNION ALL
    SELECT '고구려' COUNTRY, '3대' ST, '대무신왕'   KING_NM FROM DUAL UNION ALL
    SELECT '백제'   COUNTRY, '1대' ST, '온조왕'     KING_NM FROM DUAL UNION ALL
    SELECT '고구려' COUNTRY, '2대' ST, '유리왕'     KING_NM FROM DUAL UNION ALL
    SELECT '백제'   COUNTRY, '3대' ST, '기루왕'     KING_NM FROM DUAL UNION ALL
    SELECT '신라'   COUNTRY, '2대' ST, '남해왕'     KING_NM FROM DUAL UNION ALL
    SELECT '신라'   COUNTRY, '1대' ST, '박혁거세'   KING_NM FROM DUAL UNION ALL
    SELECT '백제'   COUNTRY, '2대' ST, '다루왕'     KING_NM FROM DUAL UNION ALL
    SELECT '신라'   COUNTRY, '3대' ST, '유리이사금' KING_NM FROM DUAL
)

--조회 쿼리
SELECT COUNTRY
     , SUBSTR(
        XMLAGG(
            XMLELEMENT(COL ,',', KING_NM) ORDER BY ST).EXTRACT('//text()'
        ).GETSTRINGVAL()
       , 2) KING_NM
  FROM TEST_TABLE
 GROUP BY COUNTRY

- 첫번째 방법에 비하여 조금 복잡해 보이나 합쳐지는 값의 구분자를 쉼표(,) 뿐만 아니라 사용자가 직접 값의 구분자를 지정 할 수 있다. 또한 해당 값의 정렬을 지정 가능 하다. 

 

□ 결과

○ 조회 전 (TEST_TABLE)

○ 조회 후


List of Articles
번호 제목 날짜 조회 수
21 피봇(Pivot)을 이용하여 행(Row)을 열(Column)로 바꾸기 file 2016.12.08 12690
20 숫자 체크 방법 (IS_NUMBER, IS_NUMERIC) file 2016.12.08 23135
19 PL/SQL에서 자바(Java) 클래스(Class), 함수 실행 방법 file 2016.12.08 9391
18 숫자를 문자로 변환 시 소수점 처리 (TO_CHAR, FM) file 2016.12.08 15027
17 여러개(다중) LIKE 검색 방법 (REGEXP_LIKE 함수) file 2016.12.08 12825
16 ROLLUP 합계, 소계 구하기 (GROUP BY) file 2016.12.08 11871
15 컬럼의 값 만큼 행(Row)을 늘리기 file 2016.12.08 14112
14 데이터베이스 백업하기 ( import : 가져오기 , export : 내보내기 ) file 2016.12.08 9889
13 오라클 DB 백업과 복원 2016.12.08 9932
12 오라클 백업 및 복구(Export, Import) file 2016.12.08 9763
11 [Oracle] DB Export, Import 방법 2016.12.08 12609
10 [Oracle] 테이블 스페이스 및 사용자 계정 생성 방법 2016.12.08 8586
9 [Oracle] Rownum을 이용한 페이징 처리 2016.12.08 10385
8 RMAN 을 이용한 오라클 백업 2016.12.08 8583
7 CentOS 6.5 에 Oracle Database 11g Release 2 설치하기 file 2016.12.08 10858
6 오라클 NULL : 값이 존재하지 않는 상태 2017.01.20 7206
5 오라클 ORDER BY : 정렬 2017.01.20 8241
4 오라클] 숫자 체크 방법 (IS_NUMBER, IS_NUMERIC) file 2017.01.20 8674
3 오늘을 기준으로 해당주(week)의 모든 일자조회 2017.01.20 8330
2 오라클 랜덤함수 2018.10.27 2150
Board Pagination Prev 1 2 3 4 5 6 7 Next
/ 7

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

© k2s0o1d4e0s2i1g5n. All Rights Reserved