>데이터 베이스 >MySQL 튜토리얼 >MySQL에서 두 날짜 사이의 영업일을 계산하는 방법은 무엇입니까?

MySQL에서 두 날짜 사이의 영업일을 계산하는 방법은 무엇입니까?

DDD
DDD원래의
2025-01-16 18:23:12282검색

How to Calculate Business Days Between Two Dates in MySQL?

MySQL에서 두 날짜 사이의 근무일 계산

Excel의 NETWORKDAYS() 함수는 지정된 두 날짜 사이의 근무일 수를 확인하는 편리한 방법을 제공합니다. 그러나 MySQL에는 유사한 내장 기능이 없습니다.

이 문제를 해결하기 위해 대안으로 사용할 수 있는 MySQL 표현식은 다음과 같습니다.

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

이 표현식에는 다음 계산이 포함됩니다.

  1. 근무일 차이 계산: (DATEDIFF(@E, @S) DIV 7) 시작 날짜 @S와 종료 날짜 @E 사이에 몇 주가 있는지 계산합니다. 전체 주 수를 구하기 위해 7로 나누고, 주당 근무일 수를 계산하기 위해 5를 곱합니다.
  2. 근무일 시작 및 종료 지수 계산: 7 WEEKDAY(@S) 및 7 WEEKDAY(@E) 시작일 및 종료일의 근무일 지수 계산( 월요일은 0, 화요일은 1 등입니다. 1을 추가하는 것은 아래에 설명된 숫자 문자열과 인덱스를 일치시키기 위한 것입니다.
  3. 요일 수 검색: MID('0123444401233334012222340111123400001234000123440', 7 * WEEKDAY(@S) WEEKDAY(@E) 1, 1) 제공된 숫자 문자열에서 단일 문자를 검색합니다. 이 문자는 지정된 근무일 조합 사이의 근무일 수를 나타냅니다.

제공된 숫자 문자열은 각 근무일 조합(월요일~월요일, 화요일~화요일 등) 사이의 근무일 수를 나타내도록 구성됩니다. 요일 인덱스를 결합하고 해당 문자를 검색하여 요일 수를 얻습니다.

가정 및 제한:

  • 이 함수는 @E가 @S보다 빠르지 않다고 가정합니다.
  • 공휴일을 무시하므로 휴일과 관련된 시나리오에서는 계산된 근무일 수가 정확하지 않을 수 있습니다.
  • 숫자 문자열은 표현식에 하드코딩되어 있으며 근무일 규칙이 다른 경우(예: 일요일이 근무일로 간주되는 경우) 업데이트해야 할 수 있습니다.

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

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