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 | - |
해결책:
피벗 테이블을 만들려면 다음 단계를 따르세요.
평균 계산: avg()
집계 함수를 사용하여 각 동네 및 침실 수 조합의 평균 가격을 계산합니다.
<code class="language-sql"> SELECT neighborhood, bedrooms, avg(price) FROM listings GROUP BY 1, 2 ORDER BY 1, 2;</code>
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!