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>
가정 및 참고 사항:
숫자 문자열 구성:
숫자 문자열은 행과 열의 시작점으로 월요일(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 중국어 웹사이트의 기타 관련 기사를 참조하세요!