gpt4 book ai didi

mysql - 将 15 日之前的星期六算作工作日并跳过其他日期

转载 作者:行者123 更新时间:2023-11-29 01:15:31 25 4
gpt4 key购买 nike

我公司的政策是我们把15天之前的星期六算作工作日,15天之后的星期六算公司假期 请告诉我计算当月工作日的函数跳过查询中15天之前的所有星期日和星期六

最佳答案

您可以使用以下代码根据您的要求计算工作日 -

CREATE FUNCTION FN_CNT_Working_days(StartDate DATE,
EndDate DATE)
RETURNS INT
BEGIN
DECLARE WORKING_DAYS INT;
SELECT
(DATEDIFF(EndDate, DATE(CONCAT(YEAR(EndDate), '-', MONTH(EndDate), '-', 16))) + 1)
-(FLOOR(DATEDIFF(EndDate, DATE(CONCAT(YEAR(EndDate), '-', MONTH(EndDate), '-', 16)))/7) * 2)
-(CASE WHEN DAYNAME(DATE(CONCAT(YEAR(EndDate), '-', MONTH(EndDate), '-', 16))) = 'Sunday' THEN 1 ELSE 0 END)
-(CASE WHEN DAYNAME(EndDate) = 'Saturday' THEN 1 ELSE 0 END)
+
(DATEDIFF(DATE(CONCAT(YEAR(EndDate), '-', MONTH(EndDate), '-', 15)), StartDate) + 1)
-(FLOOR(DATEDIFF(DATE(CONCAT(YEAR(EndDate), '-', MONTH(EndDate), '-', 15)), StartDate)/7))
-(CASE WHEN DAYNAME(StartDate) = 'Sunday' THEN 1 ELSE 0 END)
INTO WORKING_DAYS;

RETURN (WORKING_DAYS);
END;

Here是 fiddle 。此外,您还需要使用此代码处理假期。

关于mysql - 将 15 日之前的星期六算作工作日并跳过其他日期,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58425598/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com