250x250
Notice
Recent Posts
Recent Comments
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- SpringBoot
- Exception
- MSSQL
- maven
- JDBC
- oracle
- myBatis
- spring
- Core Java
- JavaScript
- Source
- git
- Python
- Eclipse
- 설정
- Spring Boot
- AJAX
- Thymeleaf
- ubuntu
- 문서
- IntelliJ
- Tomcat
- Open Source
- error
- STS
- Docker
- 오픈소스
- jpa
- MySQL
- PostgreSQL
Archives
- Today
- Total
헤르메스 LIFE
[Oracle] 로우형태의 데이터를 한줄로 표현 본문
728x90
출처 : https://2yap.wordpress.com/2012/07/09/%EB%A1%9C%EC%9A%B0%ED%98%95%ED%83%9C%EC%9D%98-%EB%8D%B0%EC%9D%B4%ED%84%B0%EB%A5%BC-%ED%95%9C%EC%A4%84%EB%A1%9C-%ED%91%9C%ED%98%84/
로우형태의 데이터를 한줄로 표현 가능하다.
SELECT
SUBSTR(MAX(SYS_CONNECT_BY_PATH (A, ',')), 2)
FROM (SELECT A,
ROW_NUMBER () OVER (PARTITION BY 1 ORDER BY A) rnum
FROM
(
SELECT 1 AS NO, 1000 AS A FROM DUAL UNION ALL
SELECT 2 AS NO, 2000 AS A FROM DUAL UNION ALL
SELECT 3 AS NO, 3000 AS A FROM DUAL
)
)
START WITH rnum = 1
CONNECT BY PRIOR rnum = rnum - 1
방법 2. 오라클 11g 용 LISTAGG 사용
기존에 세로로 나온 DATA를 가로로 바꿀때에는 쿼리가 복잡했었지만 오라클 11g에서는 LISTAGG라는 함수를 사용해서 간단하게 만들수 있다.
WITH RGN AS
(SELECT RGN_CD
FROM
(SELECT ‘A’ AS RGN_CD
FROM DUAL
UNION
SELECT ‘B’ AS RGN_CD
FROM DUAL
UNION
SELECT ‘C’ AS RGN_CD
FROM DUAL
UNION
SELECT ‘D’ AS RGN_CD
FROM DUAL
UNION
SELECT ‘E’ AS RGN_CD
FROM DUAL
)
)
SELECT LISTAGG(RGN_CD, ‘,’) WITHIN GROUP (ORDER BY RGN_CD)AS RGN_CD
FROM RGN
결과
RGN_CD
——–
A,B,C,D,E
쿼리도 복잡하지 않고 정말 한줄에 끝난다.!!
728x90
'Database' 카테고리의 다른 글
[MariaDB] MariaDB 설치 및 MySQL과의 호환성 (0) | 2016.03.30 |
---|---|
[Oracle] 테이블 생성일자 확인 (0) | 2016.03.21 |
[Oracle] Y/N 체크 쿼리 (0) | 2015.10.13 |
[Oracle] Pipelined Table Functions (0) | 2015.10.08 |
[Oracle] TRUNC, ROUND 차이 (0) | 2015.10.02 |