视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
统计当前日期距离月底有多少工作日的函数_MySQL
2020-11-09 18:04:59 责编:小采
文档


bitsCN.com
统计当前日期距离月底有多少工作日的函数 今天遇到运营那边有个需求,需要找出注册用户排除周六周日的每日打卡情况(包含不是周六周日的当天),当时的第一反应是想找一个能实现排除周六周日能计算到月底还有多少工作日的函数,找了半天没找到,还是自己写一个吧。我崇拜的王大哥也写了一个,贴出来和大家分享。代码如下: DROP FUNCTION IF EXISTS count_day_left ; DELIMITER //CREATE FUNCTION count_day_left( f_date DATETIME ) RETURNS INT DETERMINISTIC BEGIN /* Purpose: 统计指定日期距离月底还有多少个工作日,节假日未排除,用于打卡统计的过滤函数 Useage: select count_day_left('2012-09-10');*/ DECLARE start_day INT; DECLARE end_day INT; DECLARE count_day INT DEFAULT 0; DECLARE tmp_date DATE DEFAULT DATE(f_date); SET end_day=DAY(LAST_DAY(f_date)); SET start_day=DAY(f_date); WHILE start_day<=end_day DO IF ( (DAYOFWEEK(tmp_date) = 1) OR (DAYOFWEEK(tmp_date) = 7)) THEN SET tmp_date=DATE_ADD(tmp_date,INTERVAL 1 DAY); SET start_day=start_day+1; ELSE SET tmp_date=DATE_ADD(tmp_date,INTERVAL 1 DAY); SET start_day=start_day+1; SET count_day=count_day+1; END IF; END WHILE; RETURN count_day; END //DELIMITER ; DROP FUNCTION IF EXISTS count_day_left;DELIMITER //CREATE FUNCTION count_day_left(f_date DATE)RETURNS INTREADS SQL DATABEGINRETURN DATEDIFF(LAST_DAY(f_date),f_date)-(WEEK(LAST_DAY(f_date))-WEEK(f_date))*2+IF(WEEKDAY(f_date)=6,0,1)-IF(WEEKDAY(LAST_DAY(f_date))=5,1,0);END //DELIMITER ; bitsCN.com

下载本文
显示全文
专题