> 데이터 베이스 > MySQL 튜토리얼 > Oracle에서 여러 행의 열 값을 어떻게 연결할 수 있습니까?

Oracle에서 여러 행의 열 값을 어떻게 연결할 수 있습니까?

DDD
풀어 주다: 2025-01-23 15:06:09
원래의
616명이 탐색했습니다.

How Can I Concatenate Column Values from Multiple Rows in Oracle?

Oracle의 여러 행에서 열 값 연결: 포괄적인 솔루션

Oracle은 열 연결 기능을 포함하여 데이터 조작을 위한 강력한 기능을 제공합니다. 여러 행의 값. 테이블 A의 각 고유 "PID" 값에 대해 테이블 ​​B의 "Desc" 값을 결합하는 것을 목표로 하는 다음 예를 고려하십시오.

Table A:

PID
A
B
C

Table B:

PID   SEQ    Desc
A     1      Have
A     2      a nice
A     3      day.
B     1      Nice Work.
C     1      Yes
C     2      we can
C     3      do
C     4      this work!
로그인 후 복사

원하는 출력을 얻으려면 "Desc" 열이 출력 테이블에는 각 "PID"에 대해 테이블 ​​B의 "Desc" 값이 연결되어 있으므로 다음 SQL 쿼리를 사용할 수 있습니다.

SELECT pid, LISTAGG(Desc, ' ') WITHIN GROUP (ORDER BY seq) AS description
FROM B GROUP BY pid;
로그인 후 복사

이 쿼리는 지정된 열의 값을 단일 문자열로 집계하는 LISTAGG 함수입니다. GROUP BY 절을 사용하여 값이 "PID" 열을 기준으로 그룹화되었는지 확인합니다. ORDER BY 절은 값이 연결되는 순서를 추가로 지정합니다(이 경우 "SEQ" 열 기준).

프로세스를 완료하려면 이 쿼리의 출력을 테이블 A와 조인하여 필요에 따라 "PID" 값을 필터링합니다.

SELECT A.PID, description
FROM A
INNER JOIN (
    SELECT pid, LISTAGG(Desc, ' ') WITHIN GROUP (ORDER BY seq) AS description
    FROM B GROUP BY pid
) AS B ON A.PID = B.pid;
로그인 후 복사

결과 출력은 다음과 유사합니다.

PID   Desc
A     Have a nice day.
B     Nice Work.
C     Yes we can do this work!
로그인 후 복사

이 접근 방식을 통해 우리는 Oracle의 여러 행에서 열 값을 효과적으로 연결하여 데이터 변환 및 조작을 위한 강력한 도구를 제공합니다.

위 내용은 Oracle에서 여러 행의 열 값을 어떻게 연결할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿