집 >데이터 베이스 >MySQL 튜토리얼 >그룹화된 SQL 쿼리에서 고유 행에 대한 열의 합계를 계산하는 방법은 무엇입니까?
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!