- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试构建一个函数,可以从日期中减去任意数量的工作日。到目前为止我已经做到了
CREATE TEMPORARY FUNCTION working_days_diff(the_date DATE, num_of_days INT64) AS
(
CASE WHEN EXTRACT(DAYOFWEEK FROM the_date) in (2,3,4,5,6,7)
THEN
CASE WHEN (EXTRACT(DAYOFWEEK FROM the_date) - num_of_days) > 1
THEN DATE_SUB(the_date, INTERVAL num_of_days DAY)
ELSE DATE_SUB(the_date, INTERVAL (num_of_days +2) DAY)
END
ELSE
DATE_SUB(the_date, INTERVAL (num_of_days +1) DAY)
END
);
当要减去的天数相隔不到一周时,这种方法效果很好,如下例:
select working_days_diff(DATE("2018-04-12"), 3)
UNION ALL
select working_days_diff(DATE("2018-04-12"), 4)
UNION ALL
select working_days_diff(DATE("2018-04-12"), 5)
UNION ALL
select working_days_diff(DATE("2018-04-12"), 6)
UNION ALL
select working_days_diff(DATE("2018-04-12"), 7)
UNION ALL
select working_days_diff(DATE("2018-04-12"), 8)
但是当我想要减去的天数变大时,就会失败。例如:
select working_days_diff(DATE("2018-04-12"), 9) -- this should return "2018-03-30"
UNION ALL
select working_days_diff(DATE("2018-04-12"), 10) -- this should return "2018-03-29"
UNION ALL
select working_days_diff(DATE("2018-04-12"), 20) -- this should return "2018-03-15"
这个问题与我之前的问题相关: bigquery subtract 3 business days from date
最佳答案
由于您已经熟悉了正确处理某些情况但不是全部情况的版本 - 我想提供与您已有的版本尽可能最小的版本(当然假设它对于那些情况是正确的)您在问题中描述了 - 所以我只是将其扩展到其余情况)
因此,首先 - 在您的函数中,您将 num_of_days
的所有条目替换为 MOD(num_of_days, 5)
- 通过这样做,您会忽略所有条目(如果有)完整工作周(5 个工作日) - 例如,您计算相应的一天为 1 天,而不是 9 天,10 天和 20 天为 0 天,依此类推
现在,您需要从“中间”日“跳”回来,因为您在上一步中“忽略”了那么多周
为此,您将之前的结果“拥抱”到 - DATE_SUB(... , INTERVAL DIV(num_of_days, 5) WEEK)
仅此而已!
最终版本如下
#standardSQL
CREATE TEMPORARY FUNCTION working_days_diff(the_date DATE, num_of_days INT64) AS
(
DATE_SUB(CASE WHEN EXTRACT(DAYOFWEEK FROM the_date) IN (2,3,4,5,6,7)
THEN
CASE WHEN (EXTRACT(DAYOFWEEK FROM the_date) - MOD(num_of_days, 5)) > 1
THEN DATE_SUB(the_date, INTERVAL MOD(num_of_days, 5) DAY)
ELSE DATE_SUB(the_date, INTERVAL (MOD(num_of_days, 5) + 2) DAY)
END
ELSE
DATE_SUB(the_date, INTERVAL (MOD(num_of_days, 5) +1) DAY)
END, INTERVAL DIV(num_of_days, 5) WEEK)
);
您可以使用相关示例来测试/使用它
#standardSQL
CREATE TEMPORARY FUNCTION working_days_diff(the_date DATE, num_of_days INT64) AS
(
DATE_SUB(CASE WHEN EXTRACT(DAYOFWEEK FROM the_date) IN (2,3,4,5,6,7)
THEN
CASE WHEN (EXTRACT(DAYOFWEEK FROM the_date) - MOD(num_of_days, 5)) > 1
THEN DATE_SUB(the_date, INTERVAL MOD(num_of_days, 5) DAY)
ELSE DATE_SUB(the_date, INTERVAL (MOD(num_of_days, 5) + 2) DAY)
END
ELSE
DATE_SUB(the_date, INTERVAL (MOD(num_of_days, 5) +1) DAY)
END, INTERVAL DIV(num_of_days, 5) WEEK)
);
SELECT working_days_diff(DATE("2018-04-12"), 3) UNION ALL
SELECT working_days_diff(DATE("2018-04-12"), 4) UNION ALL
SELECT working_days_diff(DATE("2018-04-12"), 5) UNION ALL
SELECT working_days_diff(DATE("2018-04-12"), 6) UNION ALL
SELECT working_days_diff(DATE("2018-04-12"), 7) UNION ALL
SELECT working_days_diff(DATE("2018-04-12"), 8) UNION ALL
SELECT working_days_diff(DATE("2018-04-12"), 9) UNION ALL-- this should return "2018-03-30"
SELECT working_days_diff(DATE("2018-04-12"), 10) UNION ALL-- this should return "2018-03-29"
SELECT working_days_diff(DATE("2018-04-12"), 20) -- this should return "2018-03-15"
结果现在符合预期
Row f0_
1 2018-04-09
2 2018-04-06
3 2018-04-05
4 2018-04-04
5 2018-04-03
6 2018-04-02
7 2018-03-30
8 2018-03-29
9 2018-03-15
我觉得 - 这可以进一步优化一点 - 但我的目标是不这样做 - 而是让它尽可能接近你已经得到的 - 这样你会更容易吸收和进一步修改并根据实际用例的需要使用
关于sql - Google bigquery 从日期中减去任意数量的工作日,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49801623/
我正在使用 C#。 我知道我可以用 ToLongDateString() 显示如下内容: Friday, February 27, 2009 我喜欢做的是展示类似的东西: Febru
我将用户输入的时间和日期作为: DatePicker dp = (DatePicker) findViewById(R.id.datePicker); TimePicker tp = (TimePic
我需要检查是否 DateTime.Now是在每个月的前 3 个工作日(周一至周五)。我还需要提供一个 List有国定假日,应相应处理。 如果 DateTime.Now 是星期六并且是该月的 1 号,则
我想以 2012 年 1 月 1 日 - 2012 年 1 月 31 日的格式显示日期 并获取由 dateranges['jan 1,2012 - jan 31,2012','December 1,2
我有这两个函数可以以正确的格式 (mm-dd-yyyy) 创建一个新字符串,但现在它似乎工作得不太好......当我输入日期 31-03-2013 这是一个有效的日期,它出现在 04-01-2013
我只想在 Fullcalendar 中加载 December 月份,其中 2 个日期启用 2012 年 12 月 14 日、15 日。 var date = new Date(2012, 11); v
我创建了一个convertDate类,用于转换我的时间戳,即Date().sinceReferenceDate(即自2001年1月1日凌晨12:00起)。我有一个问题:当时间戳的日期超过 3 周前时,
我有来自两个来源的数据,我试图在日期/时间上进行匹配。问题是我没有得到匹配。所以我将日期/时间转换为 Julian 并遇到了一些奇怪的事情。 8/11/2015 6:50:22.000 42227
我正在尝试将毫秒转换为如下所示的日期:Oct 04, 2013 .我将毫秒转换为日期对象: var d1 = new Date(milliseconds); 然后输出如下内容: Fri Oct 04
我正在尝试使用 javascript 进行倒计时。但是,我的倒计时只能计算天数、小时数、分钟数和秒数。我还想显示年份和月份。 以下是我的代码: today = new Date();
我有下面的查询不适合我, 这个函数 from_tz(to_timestamp(START_TIME, 'YYYYMMDDHH24MISS'), substr(UTC_TIME_CODE_OFFSET,
例如,我有一列数据如下: 17.14.11 17.15.10 18.21.06 现在是 2017 年 11 月 14 日,我想将其更改为 DateTime 对象,例如: 2017-11-14 2017
$date1 = "2000-01-01"; $date2 = "2011-03-14"; $diff = abs(strtotime($date2) - strtotime($date1)); $y
我有以下代码来验证给定日期格式的日期: val df = new SimpleDateFormat("MM/dd/yyyy"); df.setLenient(false); try { val
我有一个包含两个 DateTime 成员的类。 但是,当我尝试将表示日期的“人类可读”值分配给 DateTime 成员时,它拒绝它并显示消息“字符串未被识别为有效的 DateTime”。 失败的代码行
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 要求提供代码的问题必须表现出对所解决问题的最低限度的了解。包括尝试的解决方案、为什么它们不起作用以及预期结果
这个问题已经有答案了: Adding days to a date in Java [duplicate] (6 个回答) 已关闭 6 年前。 如何在 java 中将给定的日期转换为日历格式。 示例初
这个问题已经有答案了: Illegal pattern character 'T' when parsing a date string to java.util.Date (4 个回答) 已关闭 6
我现在在香港。如何获取美国的年、月、日? 我已经尝试过: Calendar calendar = Calendar.getInstance(); SimpleDateFormat sdf = new
我正在尝试使用 php 和 Mysql 开发一个搜索系统,但是您如何搜索:例如当数据库中的日期格式为 2012-03-26(年/月/日)时的三月份 最佳答案 根据列数据的格式,这样的事情可能会起作用:
我是一名优秀的程序员,十分优秀!