>데이터 베이스 >MySQL 튜토리얼 >`unnest()`를 사용하여 PostgreSQL 테이블을 어떻게 전치할 수 있나요?

`unnest()`를 사용하여 PostgreSQL 테이블을 어떻게 전치할 수 있나요?

Linda Hamilton
Linda Hamilton원래의
2025-01-04 21:34:43485검색

How Can I Transpose a PostgreSQL Table Using `unnest()`?

열을 행으로 변환하여 테이블 전치

PostgreSQL에서 테이블 작업을 할 때 테이블을 전치해야 하는 상황이 있을 수 있습니다. , 기본적으로 열을 행으로 변환합니다. 이는 다양한 데이터 분석 목적에 유용한 변환입니다.

문제 설명:

다음 형식으로 데이터를 출력하는 PostgreSQL 함수 또는 테이블이 있습니다.

Sl.no username Designation salary etc..
1 A XYZ 10000 ...
2 B RTS 50000 ...
3 C QWE 20000 ...
4 D HGD 34343 ...

출력이 다음과 같이 나타나도록 이 테이블을 바꾸려고 합니다. 형식:

Sl.no 1 2 3 4 ...
Username A B C D ...
Designation XYZ RTS QWE HGD ...
Salary 10000 50000 20000 34343 ...

해결책:

이 전치를 달성하려면 PostgreSQL의 unnest() 함수를 사용할 수 있습니다. 이 함수를 사용하면 배열에서 요소를 추출하여 개별 행으로 처리할 수 있습니다.

테이블을 바꾸는 쿼리는 다음과 같습니다.

SELECT
   unnest(array['Sl.no', 'username', 'Designation','salary']) AS "Columns",
   unnest(array[Sl.no, username, value3Count,salary]) AS "Values"
FROM view_name
ORDER BY "Columns"

설명:

  • 배열[...]은 열 이름과 각 열의 해당 값을 포함하는 배열을 구성합니다.
  • unnest() 함수는 배열에서 각 요소를 추출하여 별도의 행으로 처리합니다.
  • ORDER BY 절은 전치된 테이블이 원래 열 순서를 갖도록 보장합니다.

이 쿼리는 원하는 대로 전치된 테이블을 출력합니다. format.

참조:

unnest() 함수는 PostgreSQL 문서의 "convertingColumnsToRows" 아래에 문서화되어 있습니다.

위 내용은 `unnest()`를 사용하여 PostgreSQL 테이블을 어떻게 전치할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.