여러 테이블에 걸친 데이터베이스 집계: 합계 계산 수정
데이터베이스의 여러 테이블을 처리할 때 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!