>데이터 베이스 >MySQL 튜토리얼 >침실 및 동네별 평균 가격을 표시하기 위해 PostgreSQL 테이블을 피벗하는 방법은 무엇입니까?

침실 및 동네별 평균 가격을 표시하기 위해 PostgreSQL 테이블을 피벗하는 방법은 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2025-01-13 08:26:42828검색

How to Pivot a PostgreSQL Table to Show Average Price by Bedrooms and Neighborhoods?

PostgreSQL에서 피벗 테이블 만들기

PostgreSQL은 crosstab() 함수를 사용하여 피벗 테이블을 생성합니다. 이 함수는 쿼리와 열 이름 목록이라는 두 가지 입력을 받아들입니다. 쿼리는 두 개의 열(행 머리글용 열과 데이터 값용 열)이 포함된 결과 집합을 생성해야 합니다. 열 이름 목록은 피벗해야 하는 결과 집합의 열과 일치해야 합니다.

질문:

listings이라는 다음 테이블을 고려해 보세요.

id neighborhood bedrooms price
1 downtown 0 189000
2 downtown 3 450000
3 riverview 1 300000
4 riverview 0 250000
5 downtown 1 325000
6 riverview 2 350000

침실 수를 열로, 동네를 행으로 사용하여 침실당 평균 가격을 표시하는 피벗 테이블 쿼리를 만드는 방법은 무엇입니까?

필수 출력 형식은 다음과 같아야 합니다.

neighborhood 0 1 2 3
downtown 189000 325000 - 450000
riverview 250000 300000 350000 -

해결책:

피벗 테이블을 만들려면 다음 단계를 따르세요.

  1. 평균 계산: avg() 집계 함수를 사용하여 각 동네 및 침실 수 조합의 평균 가격을 계산합니다.

    <code class="language-sql"> SELECT
       neighborhood,
       bedrooms,
       avg(price)
     FROM
       listings
     GROUP BY
       1, 2
     ORDER BY
       1, 2;</code>
  2. crosstab()에 결과 제공: 이전 쿼리의 결과를 crosstab() 함수에 제공합니다. 열 이름에 대한 값 배열을 지정하려면 $$...$$을 사용하세요. 평균을 정수로 변환하여 반올림된 결과를 얻을 수 있습니다.

    <code class="language-sql"> SELECT
       *
     FROM
       crosstab(
         'SELECT
           neighborhood,
           bedrooms,
           avg(price)::int
         FROM
           listings
         GROUP BY
           1, 2
         ORDER BY
           1, 2;',
         $$SELECT unnest('{0,1,2,3}'::int[])$$
       ) AS ct (
         "neighborhood" text,
         "0" int,
         "1" int,
         "2" int,
         "3" int
       );</code>

이 쿼리는 각 동네 내 여러 침실의 평균 가격을 기준으로 피벗하여 필요한 피벗 테이블을 생성합니다.

이 수정된 답변은 원본 이미지를 유지하고 텍스트를 그대로 복사하지 않고 유사한 의미를 갖도록 변경했습니다. 그러나 핵심 정보는 그대로 유지됩니다.

위 내용은 침실 및 동네별 평균 가격을 표시하기 위해 PostgreSQL 테이블을 피벗하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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