>데이터 베이스 >MySQL 튜토리얼 >여러 데이터베이스 테이블에서 SUM 값을 올바르게 집계하는 방법은 무엇입니까?

여러 데이터베이스 테이블에서 SUM 값을 올바르게 집계하는 방법은 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2024-12-29 05:45:11950검색

How to Correctly Aggregate SUM Values Across Multiple Database Tables?

여러 테이블에 걸친 데이터베이스 집계: 합계 계산 수정

데이터베이스의 여러 테이블을 처리할 때 SUM과 같은 집계 함수를 사용하려면 주의 깊게 처리해야 합니다. 정확한 결과를 보장합니다. 이는 [PROJECT] 및 [Value] 열이 있는 두 테이블 AP 및 INV의 값 합계를 계산하려고 시도하는 쿼리에서 예시됩니다. 원하는 출력은 다음과 유사해야 합니다.

PROJECT | SUM_AP | SUM_INV

그러나 제공된 쿼리는 합계 오류로 인해 잘못된 결과를 나타냈습니다.

SELECT AP.[PROJECT],
SUM(AP.Value) AS SUM_AP, 
SUM(INV.Value) AS SUM_INV
FROM AP INNER JOIN INV ON (AP.[PROJECT] =INV.[PROJECT])
WHERE AP.[PROJECT] = 'XXXXX'
GROUP BY AP.[PROJECT]

문제는 값 그룹화에 있습니다. GROUP BY 절은 중복된 값을 결합하여 잘못된 합계로 이어집니다.

이를 수정하려면 하위 선택을 사용할 수 있습니다.

SELECT 
    AP1.[PROJECT],
    (SELECT SUM(AP2.Value) FROM AP AS AP2 WHERE AP2.PROJECT = AP1.PROJECT) AS SUM_AP,
    (SELECT SUM(INV2.Value) FROM INV AS INV2 WHERE INV2.PROJECT = AP1.PROJECT) AS SUM_INV
FROM AP AS AP1 
    INNER JOIN INV AS INV1 
        ON (AP1.[PROJECT] =INV1.[PROJECT])
WHERE AP1.[PROJECT] = 'XXXXX'
GROUP BY AP1.[PROJECT]

이 접근 방식은 각 [PROJECT에 대해 별도로 합계를 계산합니다. ] 하위 선택을 사용하여 정확한 집계가 가능합니다.

위 내용은 여러 데이터베이스 테이블에서 SUM 값을 올바르게 집계하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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