>데이터 베이스 >MySQL 튜토리얼 >CASE WHEN 및 GROUP BY를 사용하여 SQL에서 열을 올바르게 피벗하는 방법은 무엇입니까?

CASE WHEN 및 GROUP BY를 사용하여 SQL에서 열을 올바르게 피벗하는 방법은 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2025-01-11 15:56:41569검색

How to Correctly Pivot Columns in SQL Using CASE WHEN and GROUP BY?

CASE WHEN을 사용하여 SQL 열을 피벗하고 GROUP BY 문을 수정합니다

문제 설명:

특정 조건에 따라 테이블의 열을 여러 열로 피벗하려면 SQL 쿼리에서 CASE WHEN 표현식을 사용할 수 있습니다. 그러나 이 방법을 구현할 때 그룹화가 누락되어 사용자에게 잘못된 결과가 발생할 수 있습니다.

쿼리:

이 문제를 해결하기 위해 SUM() 집계 함수 및 올바른 그룹화를 포함하는 수정된 쿼리가 아래에 제공됩니다.

<code class="language-sql">SELECT 
  name,
  SUM(CASE WHEN val = 1 THEN amount ELSE 0 END) AS amountVal1,
  SUM(CASE WHEN val = 2 THEN amount ELSE 0 END) AS amountVal2
FROM bank GROUP BY name</code>

설명:

  • 각 이름에 대한 각 값(1과 2)의 총량을 계산하려면 CASE WHEN 표현식에 SUM() 함수를 사용해야 합니다.
  • GROUP BY 이름 절은 이름 열을 기준으로 결과를 그룹화하여 각 이름에 대한 금액이 올바르게 합산되도록 합니다.

예상 결과:

이 향상된 쿼리는 원하는 결과를 생성합니다.

name amountVal1 amountVal2
John 2000 1888
Peter 1999 1854

위 내용은 CASE WHEN 및 GROUP BY를 사용하여 SQL에서 열을 올바르게 피벗하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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