고유 값에 대해 SUM()을 사용하여 SQL에서 행 그룹화
MySQL 쿼리에서 다음 값의 합계를 계산하려고 합니다. 각 행이 한 번만 계산되도록 전환표를 확인하세요. 이를 달성하려면 SUM() 함수와 함께 DISTINCT 키워드를 사용합니다. 그러나 중복 행이 SUM() 결과를 부풀리는 문제가 발생했습니다.
이 문제를 해결하려면 테이블의 기본 키 관계를 고려하세요. Conversions.id가 전환 표의 기본 키이고 stats.id가 통계 표의 기본 키인 경우 각 변환.id는 단일 link.id에 대해 고유합니다.
이러한 이해를 바탕으로 쿼리를 재구성하여 각 변환.id에 대한 변환.값의 합계를 계산한 다음 결과를 각 link.id 그룹 내의 총 행 수로 나눌 수 있습니다. 이렇게 하면 원하는 고유 값의 합계가 제공됩니다.
수정된 쿼리는 다음과 같습니다.
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;
이 쿼리는 각 link.id 그룹 내의 각 개별 Conversions.id에 대한 Conversions.value의 합계를 효과적으로 계산하여 각 행이 한 번만 계산되도록 해야 합니다.
부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.
Copyright© 2022 湘ICP备2022001581号-3