- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有由年份、该年的周数和工作日标识的日期值,我想将它们转换为简单的日期。
我找不到一个函数或其他简单的方法来组合这些,所以我想出了一个解决方法,使用 generate_series
来获取一个范围内的所有日期,并将这些提取的值与我的数据:
SELECT data.*, days.d result
FROM ( VALUES (2017, 33, 3) ) data(d_year, d_week, d_weekday)
JOIN (
SELECT
-- the potential castdate
d::date d
-- year-week-dayofweek combination for JOINing
, EXTRACT('year' FROM d) d_year, EXTRACT('week' FROM d) d_week, EXTRACT('dow' FROM d) d_weekday
FROM generate_series('2015-01-01', '2019-12-31', INTERVAL '1day') AS days(d)
) days
USING(d_year, d_week, d_weekday)
结果是:
+--------+--------+-----------+------------+
| d_year | d_week | d_weekday | result |
+--------+--------+-----------+------------+
| 2017 | 33 | 3 | 16.08.2017 |
+--------+--------+-----------+------------+
虽然这可行,但对于这样一个简单的任务来说这似乎有点过分了。此外,如果没有固定范围,这甚至可能行不通。
有更简单的方法吗?
最佳答案
您可以使用 to_date()
函数,该函数将日期字符串和格式模式作为参数。因此,如果日期字符串可能是 '2017-33-3'
,您可以采用此模式来阐明每个日期部分:
'IYYY-IW-ID'
'ID'
:棘手的部分是:您的一周是从星期日开始还是从星期一开始?这个问题会影响解决方案,因为如果您不考虑它,它会以意想不到的方式改变周数。感谢您的预期输出,我发现您需要 'ID'
(ISO 工作日,一周从星期一开始)而不是 'D'
(工作日,一周从星期日开始。) 'IW'
:因为我们采用 ISO 工作日,所以我们还需要 ISO 一年中的一周(而不是 'WW'
:一年中的一周) 'IYYY'
:类似于(2)有关日期模式(尤其是 ISO 的东西)的更多信息:Postgres documentation
SELECT to_date(d_year || '-' || d_week || '-' || d_weekday, 'IYYY-IW-ID')
如果您使用标准周模式:'YYYY-WW-D'
,您的结果将是 2017-08-13
(参见 fiddle )
当然,这在没有 -
字符的情况下也有效,但它的可读性可能较差:
SELECT to_date(d_year || d_week || d_weekday, 'IYYYIWID')
关于sql - 将 Year+WeekOfYear+DayOfWeek 转换为日期,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58204290/
我想获取两个 DayOfWeeks 之间的 DayOfWeeks 列表。 例如, Input1: DayOfWeek.MONDAY Input2: DayOfWeek.WEDNESDAY 并且输出应该
有没有办法把这段代码总结成1-2行? 我的目标是返回,例如,我有一个 DayOfWeek 是星期一,我想得到之后的一天(星期二)或之后的 n 天。 switch (_RESETDAY
我正在像这样解析日期:"Sat, 30 Jan 2016 00:03:00 +0300" 但在某些日期它抛出这个异常: Caused by: java.time.DateTimeException:
一周中的某几天是否有英文(或特定于程序员的)单一字符约定,如果有的话,这是什么?我意识到这可能是一个英语问题,但我认为它对程序员特别重要。 也许像这样: Monday Mon MO M Tu
如何获取给定年份任何的一周的第一天(日期为 1 到 7,或工作日名称)? 我尝试用 JavaScript 来解决,但我接受任何其他语言。 我需要选择一年来构建完整的日历(我想使用 HTML 表格和 J
如何获取上周的 DayOfWeek 日期? 例如 我想选择 6 月 23 日星期日作为 DayOfWeek? 我只能得到这周的DayOfWeek。 这是我的代码 DateTime today = Da
我正在使用DAYOFWEEK() MySQL 中的函数,对于星期日返回1。但在我的国家,一周从星期一开始,而不是星期日。是否有机会从 MySQL 获取星期几,格式如下:(1 - 星期一,2 - 星期二
我正在寻找一种在 MySQL 中将整数 (0-6) 转换为星期几的方法,例如: EXAMPLE_FUNCTION(3) = Wednesday. DAYOFWEEK(date)函数接受一个日期并给你一
我需要将工作日名称解析为 DayOfWeek。工作日名称可以是短格式('Mon')或长格式('Monday')。 目前我想出了这样的解决方案: DateTimeFormatter dtf = Date
在工作中,我们需要生成一份 6 个月大的报告。基本上,从5月1日到11月1日,报告必须以周为基础。到目前为止,我一次只能手动完成一周... 这是我的代码 SELECT displayname, cap
我们有 DayOfWeek在标准 ISO 8601 中定义星期几的枚举命令。 我想要一个 List这些对象的顺序适合 Locale . 我们可以很容易地确定语言环境一周的第一天。 Locale loc
我正在使用 DAYOFWEEK() MySQL 中的函数,它为 sunday 返回 1。但在我的国家,一周从星期一开始,而不是星期日。是否有机会从 MySQL 获取 dayofweek 格式如下:(1
我有一个表示星期几的简单整数列表。我正在尝试检查我的实体的 Date 属性是否在选定的一周内。但是,如果我尝试在针对数据库的查询中传递它,如下所示: query.Where(e => selected
我不知道如何在 .NET 2.0 中正确本地化 DateTime.DayOfWeek。 例子: DateTime date = DateTime.Now; // Works fine string l
这可能是一个新手问题,但这里是。 我有一种方法,其中类型 DayOfWeek 列表会附加一周中的不同日期(可能是星期三和星期六、星期日、星期一和星期五等)。 给定该列表,我需要将其与日期时间参数进行比
有没有可能得到DayOfWeek针对特定文化? 有什么线索吗? 谢谢!!! 最佳答案 尝试以下操作: DateTime.Now.ToString("dddd", new System.Globaliz
我正在尝试获取一个查询,该查询将返回一个结果集,其中包含特定小时范围内的读取总数(在 working_hours 表中定义),具体取决于 DAYOFTHEWEEK 的日期,结果如下: working
我有一个每周不同日期发生的事件列表。我希望我的查询返回从今天开始按星期几排序的结果。 'Meeting_Day' = Sunday, Monday, Tuesday... 'Day_of_Week'
我有下表 Specialoffer Id (int) ValidFrom (date) ValidTo (date) SpecialOfferExcludedDays Id (int) (F
我正在尝试计算一个值,其中我从工作日和一年中的前 3 个月获得计数。 SELECT SUM(count_LP) AS down1 FROM `splittest` WHERE DAYOFWEE
我是一名优秀的程序员,十分优秀!