首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

MySQL函数查找两个日期之间的工作日数

在云计算领域,MySQL函数是一种常见的数据库操作方式,可以用来查询、插入、更新和删除数据。要查找两个日期之间的工作日数,可以使用MySQL的内置函数和自定义函数来实现。

首先,我们可以使用MySQL的DATEDIFF函数来计算两个日期之间的天数差异。然后,我们可以使用自定义函数来计算工作日数。以下是一个示例自定义函数:

代码语言:txt
复制
CREATE FUNCTION `workdays`(start_date DATE, end_date DATE) RETURNS INT
BEGIN
  DECLARE cur_date DATE;
  DECLARE workdays INT DEFAULT 0;
  SET cur_date = start_date;
  WHILE cur_date <= end_date DO
    IF WEEKDAY(cur_date) NOT IN (5,6) THEN
      SET workdays = workdays + 1;
    END IF;
    SET cur_date = DATE_ADD(cur_date, INTERVAL 1 DAY);
  END WHILE;
  RETURN workdays;
END;

该函数接受两个日期参数,并返回两个日期之间的工作日数。它使用WEEKDAY函数来检查每个日期是否为周末,如果不是周末,则将工作日数加1。然后,它使用DATE_ADD函数来递增日期,直到达到结束日期。

要使用该函数,可以使用以下查询:

代码语言:txt
复制
SELECT workdays('2022-01-01', '2022-01-31');

该查询将返回2022年1月1日到2022年1月31日之间的工作日数。

总之,MySQL函数可以用来查找两个日期之间的工作日数,可以使用DATEDIFF函数和自定义函数来实现。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

工作日两个日期之间的数

近期遇到要求两个日期之间的工作日天数的问题。遂在网上找了下js的代码。參考了下别人的代码,发现写的都有些冗余,于是自己思考,进行了一下简单处理。主要是在循环处理上进行了精简。...对剩余天数的循环,也就能够考虑是对開始日期到剩余天数之间的处理,循环開始日期到剩余天数之间有多少个周六周日(最多仅仅有一个周六或者一个周日)。...因为当前開始日期在(0-6)之间,也就是当前開始日期的星期相应的数字加上剩余天数(0-6)的循环一定在(0-11)之间。所以0,7代表周日,6代表周六。...").value.replace(/-/g, "/")); var diffDays = (endDate - startDate)/(1000*60*60*24) + 1;//获取日期之间相差的天数...var remainDay = diffDays % 7;//得到日期之间的余数(0-6之间) var weeks = Math.floor(diffDays / 7);//获取日期之间有多少周

2.1K30
  • MySql 计算两个日期的时间差函数

    MySql计算两个日期的时间差函数 MySql计算两个日期的时间差函数TIMESTAMPDIFF用法: 语法: TIMESTAMPDIFF(interval,datetime_expr1,datetime_expr2...) 说明: 返回日期或日期时间表达式datetime_expr1 和datetime_expr2the 之间的整数差。...SELECT TIMESTAMPDIFF(MONTH,'2012-10-01','2013-01-13'); 这里比较的是两个时间的月份,返回的结果是3; 第二种方法: DATEDIFF函数,就传入两个日期函数...另外其它的日期函数, now()函数返回的是当前时间的年月日时分秒,如:2008-12-29 16:25:46 CURDATE()函数返回的是年月日信息: 如:2008-12-29 CURTIME()函数返回的是当前时间的时分秒信息...,如:16:25:46 另外,如果我们想对一个包含年月日时分秒日期格式化成年月日日期,可以使用DATE(time)函数,如 DATE(now()) 返回的是 2008-12-29

    4.2K10

    如何计算两个日期之间的天数

    计算两个日期之间的天数很实用,我一般用sq SELECT DATEDIFF("2089-10-01","2008-08-08") AS "北京奥运会开幕式天数" 如果用Go计算两个日期之间的天数,可以使用...以下是步骤和相应的代码示例: 解析日期:需要先将输入的日期字符串转换为 time.Time 类型。可以通过 time.Parse 函数来实现,它接受日期格式和日期字符串作为参数。...计算时间差:使用两个 time.Time 对象,可以通过调用它们之间的 Sub 方法来计算它们的时间差。这将返回一个 time.Duration 类型的值。...相应的 Go 代码示例: package main import ( "fmt" "time" ) // 计算两个日期之间的天数差 func daysBetweenDates(date1, date2...()-u.nsec()) 计算出来两个日期之间的差值 // sec returns the time's seconds since Jan 1 year 1. func (t *Time) sec()

    26010

    【python】---- 查找两个数之间的【可逆素数】

    问题背景 输入正整数m,n,查找[m,n]区间的可逆素数。 可逆素数:可逆素数是指该数本身是一个素数,并且把该数倒过来也是一个素数。...方法一: 最简单的方法,依次除以【从2到数字本身(不包括本身)】,不存在余数是0的数,就是素数; 思路清晰,但是效率低,比如: 假如 n 是合数,必然存在非1的两个约数 p1 和 p2 ,其中p1的,肯定能被2整除;能被6整除的肯定能被3整除!...and isPrime(onum)): return True else: False if __name__ == "__main__": m = int(input('请输入查找...【可逆素数】的开始数:')) n = int(input('请输入查找【可逆素数】的结束数:')) if(m < n): for i in range(m,n): if(isReversiblePrime

    2.2K10

    Java 8计算两个日期之间的月份

    开始日期:“2021-08-31” 结束日期:“2021-11-30” 在上述两个日期之间的91天持续时间,期望代码返回3个月的持续时间,但是以下方法仅返回2个月。这是Java 8中的bug 吗?...由于仅需要两个日期之间的月份数,请使用期间的文档来调整日期,如Jacob所述使用日期。...只需将两个实例的日期设置为相同的值(每月的第一天) Period diff = Period.between( LocalDate.parse("2021-08-31").withDayOfMonth...你的月底结束日期30不大于或等于您的月底开始日期31,因此不考虑第三个月。 注意参数名称: public static Period between?...m_calendar.get(Calendar.MONTH); return java.lang.Math.abs(nMonth2-nMonth1); } 永远不要使用LocalDateTime来计算两个日期之间的月份

    3.9K20

    Java 8计算两个日期之间的月份

    开始日期:“2021-08-31” 结束日期:“2021-11-30” 在上述两个日期之间的91天持续时间,期望代码返回3个月的持续时间,但是以下方法仅返回2个月。这是Java 8中的bug 吗?...由于仅需要两个日期之间的月份数,请使用期间的文档来调整日期,如Jacob所述使用日期。...只需将两个实例的日期设置为相同的值(每月的第一天) Period diff = Period.between( LocalDate.parse("2021-08-31").withDayOfMonth...你的月底结束日期30不大于或等于您的月底开始日期31,因此不考虑第三个月。 注意参数名称: public static Period between?...m_calendar.get(Calendar.MONTH); return java.lang.Math.abs(nMonth2-nMonth1); } 永远不要使用LocalDateTime来计算两个日期之间的月份

    6K20

    机房收费系统——用DateDiff函数计算两个日期之间的时间差

    https://blog.csdn.net/huyuyang6688/article/details/10991371        机房收费做到上机和下机部分时,需要计算从上机到下机之间的时间差...,从而计算出上机期间所花的费用。       ...这时候,可以用一个函数就可以简单的实现——DateDiff(),具体使用规则: DateDiff(timeinterval,date1,date2 [, firstdayofweek [, firstweekofyear...]])        函数返回值为从date1到date2所经历的时间,timeinterval 表示相隔时间的类型(即时间的度量单位),分别为: 年份 yyyy          季度 q              ...月份 m               每年的某一日 y  日期 d                 星期 ww             小时 h

    2.4K30

    Java 中,如何计算两个日期之间的差距?

    参考链接: Java程序计算两组之间的差异 今天继续分享一道Java面试题:  题目:Java 中,如何计算两个日期之间的差距? ...查阅相关资料得到这些知识,分享给大家:  java计算两个日期相差多少天小时分钟等    转载2016年08月25日 11:50:00  1、时间转换  data默认有toString() 输出格林威治时间...,比如说Date date = new Date(); String toStr = date.toString(); 输出的结果类似于: Wed Sep 16 19:02:36 CST 2012   ...ss").format(date); System.out.println(dateStr); 输出结果像下面这样: 2009-09-16 07:02:36当然啦,你也可以把:hh:mm:ss去掉,输出的结果也就只有年...1000* 24* 60* 60;     longnh = 1000* 60* 60;     longnm = 1000* 60;     // long ns = 1000;     // 获得两个时间的毫秒时间差异

    7.6K20

    小工具|计算两个日期之间的天数?

    计算两个日期的间距 在开发中我们常要使用到日期格式的转换或者是计算两个时间的间距,因此很有必要自己封装一个通用的工具类方便自己以后调用使用,方便自己的开发,也可使项目更简洁。...一、当传参是两个Date类型时: /** * 计算两个日期之间相差的天数 * @param date1 较小的时间 * @param date2 较大的时间 *...@return 相差天数 * @throws ParseException * calendar 对日期进行时间操作 * getTimeInMillis() 获取日期的毫秒显示形式...string类型时: /** * 字符串日期格式的计算 * @param date1 较小的日期 * @param date2 较大的日期 * @return...date日期格式的计算 * @param date1 * @param date2 * @return * @throws ParseException

    3.2K30
    领券