>데이터 베이스 >MySQL 튜토리얼 >MySQL에서 고유 행에 대한 SUM()을 계산하는 방법은 무엇입니까?

MySQL에서 고유 행에 대한 SUM()을 계산하는 방법은 무엇입니까?

DDD
DDD원래의
2024-11-04 15:32:02466검색

How to Calculate SUM() for Distinct Rows in MySQL?

MySQL의 고유 행에 대한 SUM()

MySQL 쿼리에서 SUM() 집계 함수를 활용할 때, 정확한 계산을 위해 개별 행이 계산됩니다. 제공된 예에서 목표는 개별 전환을 계산하고 해당 값을 합산하는 것입니다.

원래 쿼리에서 SUM(conversions.value) 함수는 GROUP BY로 인해 각 행의 값을 여러 번 계산합니다. link.id. 이 문제를 해결하려면 별도의 Conversions.id에 대해서만 Conversions.value를 합산해야 합니다.

꼼꼼한 분석에 따르면 Conversions.id와 stats.id가 모두 기본 키인 것으로 나타났습니다. 따라서 각 Conversions.id에 대해 고유한 link.id가 있다고 가정할 수 있습니다.

원하는 결과를 얻기 위해 클릭수와 전환수를 나타내는 두 집합의 데카르트 곱을 활용할 수 있습니다. 순 전환수는 count(distinct Conversions.id)를 사용하여 도출할 수 있습니다.

전환 가치의 합계는 순 전환수를 총 횟수로 나눈 값(sum(conversions.id))과 곱하여 수정할 수 있습니다. value)count(distinct Conversions.id)/count()

이 수정 사항을 통합하면 다음과 같이 수정된 쿼리가 생성됩니다.

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;

이 세련된 쿼리는 중복 행을 효과적으로 제거합니다. Conversion_value 계산 시 개별 전환에 대한 정확한 합계를 보장합니다.

위 내용은 MySQL에서 고유 행에 대한 SUM()을 계산하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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