>  기사  >  데이터 베이스  >  MySQL에서 0 값을 포함하여 날짜 범위 내의 모든 달을 추출하는 방법은 무엇입니까?

MySQL에서 0 값을 포함하여 날짜 범위 내의 모든 달을 추출하는 방법은 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-11-03 19:42:29379검색

How to Extract All Months within a Date Range, Including Zero Values in MySQL?

0 값을 포함하여 날짜 범위 내의 모든 월 추출

MySQL에서는 특정 날짜 내의 월별 평균 값을 추출하는 것이 가능합니다. 특정 달의 값이 0인 경우에도 범위입니다. 이 기능은 모든 월을 정확하게 계산하고 표시하는 데 매우 중요합니다.

이를 달성하기 위한 한 가지 접근 방식은 필수 범위 내에서 가능한 모든 월을 포함하는 "dateTable"을 만드는 것입니다. 이 테이블은 "날짜", "월", "연도" 등과 같은 열로 채워질 수 있습니다.

그런 다음 원래 쿼리를 수정하여 "dateTable"을 사용하여 LEFT JOIN을 수행할 수 있습니다. 일치하는 날짜 열. 이렇게 하면 기본 테이블에 해당 항목이 있는지 여부에 관계없이 지정된 날짜 범위의 모든 월이 검색됩니다. 쿼리는 다음과 유사합니다.

SELECT `DT`.`myYear`, `DT`.`myMonth`,
AVG(`myTable`.`value1`) AS avg_value_1,
AVG(`myTable`.`value2`) AS avg_value_2
FROM `dateTable` AS DT
LEFT JOIN `myTable`
ON `dateTable`.`myDate` = `myTable`.`save_date`
WHERE `dateTable`.`myDate` BETWEEN '2009-01-01' AND '2009-07-01'
GROUP BY `DT`.`myYear`, `DT`.`myMonth`

이 수정을 통해 "dateTable"에 포함된 모든 열을 기반으로 유연한 보고가 가능해졌습니다. 예를 들어 "재무 분기" 또는 "요일"별로 그룹화하려면 "GROUP BY" 절을 적절하게 조정하면 됩니다.

LEFT JOIN과 포괄적인 "dateTable"을 활용하면 이 접근 방식은 효과적으로 검색합니다. 지정된 날짜 범위 내의 모든 달을 사용하여 값이 0인 달도 출력에 포함되도록 합니다.

위 내용은 MySQL에서 0 값을 포함하여 날짜 범위 내의 모든 달을 추출하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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