希望计算2个日期之间的平日数 [英] wanting to count the number of weekdays between 2 dates

查看:138
本文介绍了希望计算2个日期之间的平日数的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我有一个开始和结束日期。

I am given a start and end date.

我想计算这两个日期之间的平日数。

i want to count the number of weekdays between those 2 dates.

然后在日期表中,我想以类似的方式来计数,只能选择周末。

then in a table of dates, i want to count those in a similar fashion to to pick weekends only.

有人可以帮助我吗? / p>

Could someone help me on this?

推荐答案

一种方法是具有日期/日期的物化表。但是,用于构建此物化表的相同方法可以直接在查询中使用。我显示了几个[工作日]计算,但您可以使用相同的方法来查询周末天数(周末日值为5和6):

One approach is to have a materialized table of days / dates. But this same method, used to build this materialized table, can be used directly in a query. I show a couple of [weekday] calculations, but you can use the same approach to query about weekend days (weekend day values are 5, and 6):

直接单查询示例:

SELECT day
     , WEEKDAY(day) AS wkday
  FROM (
SELECT FROM_DAYS(d.day1+v1.result) AS day
  FROM (SELECT TO_DAYS(DATE('2000-01-01')) AS day1
             , TO_DAYS(DATE('2021-01-01')) AS day2
     ) AS d
  JOIN (
      SELECT v1.num+v2.num+v3.num+v4.num AS result
        FROM (
                 SELECT 1 AS num UNION SELECT 2 UNION SELECT 3 UNION SELECT 4 UNION SELECT 5
           UNION SELECT 6 UNION SELECT 7 UNION SELECT 8 UNION SELECT 9 UNION SELECT 0
           ) AS v1
        JOIN (
                 SELECT 10 AS num UNION SELECT 20 UNION SELECT 30 UNION SELECT 40 UNION SELECT 50
           UNION SELECT 60 UNION SELECT 70 UNION SELECT 80 UNION SELECT 90 UNION SELECT 00
           ) AS v2
        JOIN (
                 SELECT 100 AS num UNION SELECT 200 UNION SELECT 300 UNION SELECT 400 UNION SELECT 500
           UNION SELECT 600 UNION SELECT 700 UNION SELECT 800 UNION SELECT 900 UNION SELECT 000
           ) AS v3
        JOIN (
                 SELECT 1000 AS num UNION SELECT 2000 UNION SELECT 3000 UNION SELECT 4000 UNION SELECT 5000
           UNION SELECT 6000 UNION SELECT 7000 UNION SELECT 8000 UNION SELECT 9000 UNION SELECT 0000
           ) AS v4
     ) v1
 WHERE v1.result < (d.day2-d.day1)
     ) AS days
 WHERE WEEKDAY(day) < 5
 LIMIT 10
;



USE test;

DROP TABLE IF EXISTS days;

CREATE TABLE days (
   day   date PRIMARY KEY
) ENGINE = InnoDB;

INSERT INTO days
SELECT FROM_DAYS(d.day1+v1.result)
  FROM (SELECT TO_DAYS(DATE('2000-01-01')) AS day1
             , TO_DAYS(DATE('2021-01-01')) AS day2
     ) AS d
  JOIN (
      SELECT v1.num+v2.num+v3.num+v4.num AS result
        FROM (
                 SELECT 1 AS num UNION SELECT 2 UNION SELECT 3 UNION SELECT 4 UNION SELECT 5
           UNION SELECT 6 UNION SELECT 7 UNION SELECT 8 UNION SELECT 9 UNION SELECT 0
           ) AS v1
        JOIN (
                 SELECT 10 AS num UNION SELECT 20 UNION SELECT 30 UNION SELECT 40 UNION SELECT 50
           UNION SELECT 60 UNION SELECT 70 UNION SELECT 80 UNION SELECT 90 UNION SELECT 00
           ) AS v2
        JOIN (
                 SELECT 100 AS num UNION SELECT 200 UNION SELECT 300 UNION SELECT 400 UNION SELECT 500
           UNION SELECT 600 UNION SELECT 700 UNION SELECT 800 UNION SELECT 900 UNION SELECT 000
           ) AS v3
        JOIN (
                 SELECT 1000 AS num UNION SELECT 2000 UNION SELECT 3000 UNION SELECT 4000 UNION SELECT 5000
           UNION SELECT 6000 UNION SELECT 7000 UNION SELECT 8000 UNION SELECT 9000 UNION SELECT 0000
           ) AS v4
     ) v1
 WHERE v1.result < (d.day2-d.day1)
;

SELECT *
  FROM days
 ORDER BY day
 LIMIT 10
;


SELECT COUNT(*) FROM days;

SELECT MIN(day), MAX(day) FROM days;

SELECT day, WEEKDAY(day) FROM days LIMIT 6;

SELECT day, WEEKDAY(day) AS wkday FROM days WHERE WEEKDAY(day) < 5 LIMIT 6;

SELECT COUNT(*), MIN(day), MAX(day) FROM days WHERE WEEKDAY(day) < 5;

这篇关于希望计算2个日期之间的平日数的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆