각 행이 한 번만 계산되도록 하면서 SQL에서 값의 합계를 계산하는 방법은 무엇입니까?

Barbara Streisand
풀어 주다: 2024-11-08 05:56:02
원래의
660명이 탐색했습니다.

How To Calculate the Sum of a Value in SQL While Ensuring Each Row is Counted Only Once?

고유 값에 대해 SUM()을 사용하여 SQL에서 행 그룹화

MySQL 쿼리에서 다음 값의 합계를 계산하려고 합니다. 각 행이 한 번만 계산되도록 전환표를 확인하세요. 이를 달성하려면 SUM() 함수와 함께 DISTINCT 키워드를 사용합니다. 그러나 중복 행으로 인해 SUM() 결과가 부풀려지는 문제가 발생했습니다.

이 문제를 해결하려면 테이블의 기본 키 관계를 고려하세요. Conversions.id가 전환 표의 기본 키이고 stats.id가 통계 표의 기본 키인 경우 각 변환.id는 단일 link.id에 대해 고유합니다.

이러한 이해를 바탕으로 쿼리를 재구성하여 각 변환.id에 대한 변환.값의 합계를 계산한 다음 결과를 각 link.id 그룹 내의 총 행 수로 나눌 수 있습니다. 이렇게 하면 원하는 고유 값 합계가 제공됩니다.

수정된 쿼리는 다음과 같습니다.

<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>
로그인 후 복사

이 쿼리는 내의 각 고유 Conversions.id에 대한 Conversions.value 합계를 효과적으로 계산해야 합니다. 각 link.id 그룹은 각 행이 한 번만 계산되도록 합니다.

위 내용은 각 행이 한 번만 계산되도록 하면서 SQL에서 값의 합계를 계산하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿