>데이터 베이스 >MySQL 튜토리얼 >총 합계를 위해 SQL에서 날짜별로 현금 가치를 필터링하는 방법은 무엇입니까?

총 합계를 위해 SQL에서 날짜별로 현금 가치를 필터링하는 방법은 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2025-01-05 03:11:43489검색

How to Filter Cash Values by Date in SQL for Total Summation?

SQL에서 날짜 필터링을 사용하여 현금 가치 합계

언급하신 대로 각 고유 거래에 대한 총 현금을 계산하는 SQL 문이 있습니다. 다음 줄을 사용하여 ID를 확인하세요.

select sum(cash) from Table a where a.branch = p.branch and a.transID = p.transID) TotalCash

이 명세서를 결제 날짜가 있는 총 현금 가치로만 수정하려면 지난달 이내에는 다음과 같은 방법으로 업데이트할 수 있습니다.

select SUM(CASE WHEN ValueDate > @startMonthDate THEN cash ELSE 0 END)
from Table a where a.branch = p.branch and a.transID = p.transID) TotalMonthCash

설명:

  • CASE WHEN...THEN. ..ELSE...END: 부울 표현식(이 경우 ValueDate)을 비교하는 검색된 CASE 표현식 구문입니다. > @startMonthDate)를 결과 세트에 추가합니다. 부울 표현식이 true이면 현금 가치를 반환합니다. 그렇지 않으면 0을 반환합니다.
  • SUM(): 날짜 필터링 기준에 맞는 현금 가치의 합계를 계산하는 함수입니다.

성능 최적화:

참고로, 쿼리 성능이 문제가 있는 경우 종속 하위 쿼리 대신 JOIN 및 GROUP BY를 사용하여 다시 작성하는 것이 좋습니다. 이렇게 하면 실행 시간이 잠재적으로 향상될 수 있습니다.

위 내용은 총 합계를 위해 SQL에서 날짜별로 현금 가치를 필터링하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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