>  기사  >  데이터 베이스  >  그룹화된 SQL 쿼리에서 고유 행에 대한 열의 합계를 계산하는 방법은 무엇입니까?

그룹화된 SQL 쿼리에서 고유 행에 대한 열의 합계를 계산하는 방법은 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2024-11-03 19:07:29522검색

How to Calculate the Sum of a Column for Unique Rows in a Grouped SQL Query?

MYSQL: 고유 행에 sum() 사용

SQL 쿼리에서 sum() 함수는 일반적으로 다음의 합계를 계산하는 데 사용됩니다. 여러 행의 값. 그러나 그룹화된 데이터로 작업할 때는 중복 행을 고려하는 것이 필수적입니다. 이 특정 질문에서 사용자는 전환 테이블의 각 개별 행에 대한 Conversions.value 열의 합계를 계산하는 것을 목표로 합니다.

제공된 쿼리에서는 처음에 sum(conversions.value)이 잘못 계산하는 문제가 발생합니다. GROUP BY 절로 인해 각 행의 값이 여러 번 발생했습니다. 이 문제를 해결하려면 사용자는 고유한 행에 대해서만 합계가 계산되도록 해야 합니다.

해결책은 여러 집합의 요소를 결합하는 데카르트 곱 개념을 활용하는 것입니다. 이 경우 세트는 고유한 클릭 및 전환 이벤트입니다. count(DISTINCT Conversions.id) 함수는 중복된 전환 행을 효과적으로 제거하여 고유한 전환 이벤트 수를 제공합니다.

올바른 합계를 계산하려면 사용자는 sum(conversions.value)에 고유 전환 수를 곱하면 됩니다. 전환수를 총 행 수(count(*))로 나눕니다. 이 작업을 통해 각 링크와 관련된 고유 전환 이벤트에 대해서만 합계가 계산됩니다.

솔루션에서 권장되는 수정된 쿼리는 다음과 같습니다.

<code class="sql">SELECT links.id, 
       count(DISTINCT stats.id) as clicks, 
       count(DISTINCT conversions.id) as conversions, 
       sum(conversions.value)*count(DISTINCT conversions.id)/count(*) as conversion_value 
FROM links 
LEFT OUTER JOIN stats ON links.id = stats.parent_id 
LEFT OUTER JOIN conversions ON links.id = conversions.link_id 
GROUP BY links.id 
ORDER BY links.created desc;</code>

위 내용은 그룹화된 SQL 쿼리에서 고유 행에 대한 열의 합계를 계산하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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