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>
로그인 후 복사
이 표현식에는 다음 계산이 포함됩니다.
-
근무일 차이 계산: (DATEDIFF(@E, @S) DIV 7) 시작 날짜 @S와 종료 날짜 @E 사이에 몇 주가 있는지 계산합니다. 전체 주 수를 구하기 위해 7로 나누고, 주당 근무일 수를 계산하기 위해 5를 곱합니다.
-
근무일 시작 및 종료 지수 계산: 7 WEEKDAY(@S) 및 7 WEEKDAY(@E) 시작일 및 종료일의 근무일 지수 계산( 월요일은 0, 화요일은 1 등입니다. 1을 추가하는 것은 아래에 설명된 숫자 문자열과 인덱스를 일치시키기 위한 것입니다.
-
요일 수 검색: MID('0123444401233334012222340111123400001234000123440', 7 * WEEKDAY(@S) WEEKDAY(@E) 1, 1) 제공된 숫자 문자열에서 단일 문자를 검색합니다. 이 문자는 지정된 근무일 조합 사이의 근무일 수를 나타냅니다.
제공된 숫자 문자열은 각 근무일 조합(월요일~월요일, 화요일~화요일 등) 사이의 근무일 수를 나타내도록 구성됩니다. 요일 인덱스를 결합하고 해당 문자를 검색하여 요일 수를 얻습니다.
가정 및 제한:
- 이 함수는 @E가 @S보다 빠르지 않다고 가정합니다.
- 공휴일을 무시하므로 휴일과 관련된 시나리오에서는 계산된 근무일 수가 정확하지 않을 수 있습니다.
- 숫자 문자열은 표현식에 하드코딩되어 있으며 근무일 규칙이 다른 경우(예: 일요일이 근무일로 간주되는 경우) 업데이트해야 할 수 있습니다.
위 내용은 MySQL에서 두 날짜 사이의 영업일을 계산하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!