집 >데이터 베이스 >MySQL 튜토리얼 >함수나 프로시저를 사용하지 않고 Oracle SQL에서 두 날짜 사이의 영업일을 정확하게 계산하는 방법은 무엇입니까?
Oracle SQL에서 영업일 계산(함수 또는 프로시저 없이)
다음 공식을 사용하여 Oracle SQL에서 두 날짜 사이의 영업일을 계산하는 동안:
((to_char(CompleteDate,'J') - to_char(InstallDate,'J')) 1) - (((to_char(CompleteDate,'WW') (52 ((to_char(CompleteDate,'YYYY') - to_char(InstallDate,'YYYY')))) ) - to_char(InstallDate,'WW'))2)
결과가 나올 수 있음 대부분 정확한 결과이지만 때로는 2일 이하로 차이가 나는 경우도 있습니다. 이러한 불일치는 다음 요소를 무시하는 데서 발생합니다.
이러한 문제를 해결하려면 더 정확한 공식이 필요합니다. is:
(TRUNC(CompleteDate) - TRUNC(InstallDate) ) 1 -
((((TRUNC(CompleteDate,'D'))-(TRUNC(InstallDate,'D')))/ 7)*2) -
(경우 TO_CHAR(InstallDate,'DY','nls_date_언어=english')='SUN' THEN 1 ELSE 0 END) -
(CASE WHEN TO_CHAR(CompleteDate,'DY','nls_date_언어=english')='SAT' THEN 1 ELSE 0 END)
여기서 TRUNC()는 날짜에서 시간 구성 요소를 사용하고 TO_CHAR()는 요일을 추출합니다. 이제 계산에서는 잘린 날짜 사이의 일수를 통합하고 주말을 빼고 주말 시작일 또는 종료일을 조정합니다.
이러한 개선 사항을 통합함으로써 공식은 Excel의 NETWORKDAYS 함수에 맞춰 영업일을 정확하게 계산합니다. .
위 내용은 함수나 프로시저를 사용하지 않고 Oracle SQL에서 두 날짜 사이의 영업일을 정확하게 계산하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!