mysql计算除周六周天后2个日期差值

计算2个日期的差值,并排除周六周天的函数

DECLARE startDay DATE DEFAULT null;
	DECLARE enddate DATE DEFAULT null;
	-- DECLARE diff_days Int DEFAULT null;
	DECLARE startDay_add DATE DEFAULT null;
	DECLARE enddate_minus DATE DEFAULT null;
	DECLARE num1 INT DEFAULT null;  -- 2者之间的差值计算
	DECLARE num2 INT DEFAULT null; 
	-- 起始时间
	set @startDay = InDay;  
-- 年底结束时间	
	set @enddate = last_day( date_format( now( ), '%Y-12-31' ));  
-- 开始时间到结束时间的差值	
	-- set @diff_days = timestampdiff( day, now(), last_day( date_format( now( ), '%Y-12-31' ) ) )+1 ;  
	-- 开始时间的本周末日期(开始时间+)
	set @startDay_add = date_sub(@startDay,INTERVAL (DATE_FORMAT(@startDay,'%w')-7) day);
	-- 结束时间上周末的日期
	set @enddate_minus = DATE_SUB(@enddate,INTERVAL DATE_FORMAT(@enddate,'%w') day);
	-- 整数周的差值天数
	set @num1 = timestampdiff(day,@startDay_add,@enddate_minus)/7*5;
	-- 计算总天数(除周六、周天)
	set @num2 = 
	CASE 
	WHEN DATE_FORMAT(@startDay,'%w') < 6 and DATE_FORMAT(@enddate,'%w') = 6 THEN @num1 + (5-DATE_FORMAT(@startDay,'%w')) + DATE_FORMAT(@enddate,'%w') -1
	WHEN DATE_FORMAT(@startDay,'%w') < 6 and DATE_FORMAT(@enddate,'%w') = 7 THEN @num1 + (5-DATE_FORMAT(@startDay,'%w')) + DATE_FORMAT(@enddate,'%w') -2
	WHEN DATE_FORMAT(@startDay,'%w') >= 6 and DATE_FORMAT(@enddate,'%w') < 6 THEN @num1 + DATE_FORMAT(@enddate,'%w')
	WHEN DATE_FORMAT(@startDay,'%w') >= 6 and DATE_FORMAT(@enddate,'%w') = 6 THEN @num1 + DATE_FORMAT(@enddate,'%w') -1
	WHEN DATE_FORMAT(@startDay,'%w') >= 6 and DATE_FORMAT(@enddate,'%w') = 7 THEN @num1 + DATE_FORMAT(@enddate,'%w') -2
	ELSE -- 开始时间<=周五,结束时间<=周五
		@num1 + (5-DATE_FORMAT(@startDay,'%w')) + DATE_FORMAT(@enddate,'%w') 
END 
 ;
	RETURN @num2;	
END 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用以下步骤来计算两个日期之间排除法定节假日和周六周日的工作日天数: 1. 首先,创建一个包含所有法定节假日的列表。你可以根据你所在的国家或地区来确定这些日期。 2. 然后,创建一个方法来判断给定的日期是否为法定节假日。在该方法中,你可以将给定的日期与法定节假日列表进行比较,如果日期匹配任何一个法定节假日,则返回true,否则返回false。 3. 接下来,创建一个方法来判断给定的日期是否为周末(即星期六或星期日)。你可以使用Java中的Calendar类来获取给定日期的星期几,并判断是否为周末。 4. 然后,创建一个方法来计算两个日期之间的工作日天数。在该方法中,你可以使用一个循环来遍历两个日期之间的每一天。对于每一天,你需要判断它是否为法定节假日或周末,如果不是,则将工作日天数加1。 5. 最后,调用这个方法,并传入要计算两个日期,即可得到排除法定节假日和周末的工作日天数。 以下是一个简单示例代码: ```java import java.util.Calendar; public class WorkingDaysCalculator { // 创建法定节假日列表 private static final String[] HOLIDAYS = { "2022-01-01", "2022-01-02", // 示例日期,请根据实际情况修改 // ... 添加其他法定节假日 }; // 判断给定日期是否为法定节假日 private static boolean isHoliday(String date) { for (String holiday : HOLIDAYS) { if (holiday.equals(date)) { return true; } } return false; } // 判断给定日期是否为周末 private static boolean isWeekend(String date) { Calendar calendar = Calendar.getInstance(); calendar.set(Integer.parseInt(date.substring(0, 4)), Integer.parseInt(date.substring(5, 7)) - 1, Integer.parseInt(date.substring(8))); int dayOfWeek = calendar.get(Calendar.DAY_OF_WEEK); return dayOfWeek == Calendar.SATURDAY || dayOfWeek == Calendar.SUNDAY; } // 计算两个日期之间的工作日天数(排除法定节假日和周末) public static int calculateWorkingDays(String startDate, String endDate) { int workingDays = 0; Calendar start = Calendar.getInstance(); start.set(Integer.parseInt(startDate.substring(0, 4)), Integer.parseInt(startDate.substring(5, 7)) - 1, Integer.parseInt(startDate.substring(8))); Calendar end = Calendar.getInstance(); end.set(Integer.parseInt(endDate.substring(0, 4)), Integer.parseInt(endDate.substring(5, 7)) - 1, Integer.parseInt(endDate.substring(8))); // 循环遍历两个日期之间的每一天 while (!start.after(end)) { String currentDate = String.format("%04d-%02d-%02d", start.get(Calendar.YEAR), start.get(Calendar.MONTH) + 1, start.get(Calendar.DAY_OF_MONTH)); // 判断当前日期是否为法定节假日或周末 if (!isHoliday(currentDate) && !isWeekend(currentDate)) { workingDays++; } // 将日期增加一天 start.add(Calendar.DAY_OF_MONTH, 1); } return workingDays; } public static void main(String[] args) { String startDate = "2022-01-01"; // 开始日期,请根据实际情况修改 String endDate = "2022-01-07"; // 结束日期,请根据实际情况修改 int workingDays = calculateWorkingDays(startDate, endDate); System.out.println("工作日天数:" + workingDays); } } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值