>데이터 베이스 >MySQL 튜토리얼 >MySQL에서 두 날짜 사이의 영업일을 계산하는 방법(공휴일 제외)?

MySQL에서 두 날짜 사이의 영업일을 계산하는 방법(공휴일 제외)?

Barbara Streisand
Barbara Streisand원래의
2025-01-16 18:10:09799검색

How to Calculate Business Days Between Two Dates in MySQL (Without Holidays)?

MySQL 함수는 두 날짜 사이의 근무일 수를 계산합니다(공휴일 제외)

Excel의 NETWORKDAYS() 함수는 두 날짜 사이의 근무일 수를 편리하게 계산할 수 있으며 MySQL에도 유사한 기능이 필요합니다. 휴일을 처리하는 것이 더 복잡하기는 하지만 여기서는 휴일을 고려하지 않는 단순화된 솔루션이 필요합니다.

해결책:

다음 표현식은 시작 날짜 @S와 종료 날짜 @E 사이의 영업일 수를 효과적으로 계산합니다.

<code class="language-sql">5 * (DATEDIFF(@E, @S) DIV 7) + MID('0123444401233334012222340111123400001234000123440', 7 * WEEKDAY(@S) + WEEKDAY(@E) + 1, 1)</code>

가정 및 참고 사항:

  • 종료 날짜(@E)는 시작 날짜(@S) 이전일 수 없습니다.
  • DATEDIFF와 유사하게 시작일과 종료일이 동일하면 영업일이 0이 됩니다.
  • 휴일은 고려되지 않습니다.

숫자 문자열 구성:

숫자 문자열은 행과 열의 시작점으로 월요일(WEEKDAY 0)을 사용하여 시작 및 종료 날짜의 테이블로 주의 깊게 구성됩니다. 왼쪽 위 모서리에서 오른쪽 아래 모서리까지의 대각선은 0으로 채워져 있습니다. 이는 같은 주의 날짜 사이에 근무일이 없음을 나타냅니다(예: 월요일부터 월요일까지).

오른쪽 대각선으로 이동하면 해당 날짜가 주말(휴일)이 아닌 경우에만 매일 0이 아닌 근무일이 계산됩니다. 줄의 끝에 도달하면 같은 줄의 시작 부분으로 카운트가 돌아갑니다. 이 과정은 다음 대각선을 만날 때까지 계속됩니다.

표현 개선:

수정 후 개선된 표현은 다음과 같습니다.

<code class="language-sql">5 * (DATEDIFF(@E, @S) DIV 7) + MID('0123444401233334012222340111123400001234000123440', 7 * WEEKDAY(@S) + WEEKDAY(@E) + 1, 1)</code>

이 개선된 표현식은 향상된 숫자 문자열을 사용하여 더욱 정확한 결과를 제공합니다.

위 내용은 MySQL에서 두 날짜 사이의 영업일을 계산하는 방법(공휴일 제외)?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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