- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在编写一个“此时向我发送消息”应用程序。我以这种方式存储重复信息:
Schedules
----------
days_of_week: [3, 4, 5]
hours_of_day: [8, 13, 22]
time_zone: "Pacific Time (US & Canada)"
在显示方面效果很好,但我需要编写一个频繁的 cron 作业来获取“现在 (utc)”的所有时间表。因此,如果 cron 作业在星期一 09:00 UTC 运行,我需要获取所有计划,其中
where days_of_week @> ARRAY[1]
)hours_of_day
为 09:00 UTC。假设 hours_of_day
存储为整数数组,但我们还存储了用户的时区。所以用户可能会说:“在星期一上午 9 点给我发消息”(我们将其存储为 [9]),但这意味着 他们 时区的上午 9 点。
问题:
提前致谢!
最佳答案
Postgres 具有处理时区的一流工具,我已经使用 AT TIME ZONE 编写了与您在此询问的内容非常相似的内容。构造。除了您的字段之外,我还使用 last_scheduled_at
来标记最后一次“执行”计划的时间——即最后一次成功的 cron 作业何时为该计划运行以避免双重计划,以及 deleted_at
用于计划的逻辑删除。
除了我只有一个小时之外,我的时间表架构很相似。我像你一样将天数存储在一个数组中,并将时区存储为 text
。我的 schedules
表中的字段是 dows
、hour
和 timezone
。
这是查询:
SELECT
s.*
FROM
schedules s
WHERE
ARRAY[extract(dow from timestamptz (now() at time zone timezone))] && dows
AND hour = extract(hour from timestamptz (now() at time zone timezone))
AND (s.last_scheduled_at IS NULL
OR s.last_scheduled_at < (now() - interval '12 hours'))
AND s.deleted_at IS NULL
LIMIT
1000
我使用 &&
(重叠)而不是 @>
(包含),但两者都有效。您可能还需要限制,以便您可以分批处理工作(继续运行它,如果结果为零,您将完成 X 小时;确保在小时结束之前完成)。您可能还想将时间戳作为参数传递给此查询——我在这里将其内联为 now()
以简化操作,但将时间作为参数传递会使测试成为一个容易多了。
另请注意,Postgres 可能对时区名称和缩写很挑剔,它的夏令时行为可能违反直觉:例如,太平洋标准时间和太平洋夏令时被视为两个不同的时区(出于 在时区
):
maciek=# select now() at time zone 'pst';
timezone
----------------------------
2015-10-09 23:14:51.856813
(1 row)
maciek=# select now() at time zone 'pdt';
timezone
----------------------------
2015-10-10 00:14:54.402524
(1 row)
也就是说,夏令时始终存在,无论您当前是否在观察它。如果您让人们直接输入时区,最好拒绝这些或自动将它们强制为“America/Los_Angeles”(或他们碰巧映射到的任何时区),这将根据以下内容自动为您处理这些转换您的 Postgres 版本具有的时区规则(如果对于经常更改时区的区域,准确性至关重要,请确保您及时更新到点发布)。 Postgres 使用的时区名称列表可以在 Olson database 中找到。 . Postgres 表 pg_timezone_names 和 pg_timezone_abbrevs也可能感兴趣。
关于postgresql - Postgres : query schedule given day, time_of_day,和时区名称,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33050668/
我想使用结构 DataResponse 作为 JSON() 的参数来响应用户。通过初始化 DataResponse 的实例,我得到了错误消息,给出了太多的参数,但给出了所有必要的参数。 type Da
我正在尝试将 google-one-tap 与本地主机上的 django 项目集成。所以我在 Client ID for Web 的 Authorized JavaScript origins 中添加
考虑一个类A,我如何编写一个具有与相同行为的模板 A& pretty(A& x) { /* make x pretty */ return x; } A pretty(A&& x) {
我正在使用 Hibernate envers 3.6.3.Final。我可以审核表,我可以看到 _audit 表中填充了 revision_number、revision_type 和实体数据。 我正
问题详细描述如下: 给定两个单词(beginWord 和 endWord)和字典的单词列表,找出是否存在从 beginWord 到 endWord 的转换序列,这样: 一次只能更改一个字母 每个转换后
我正在尝试解析任何选定的 mysql 表的单行的所有列字段和数据。 这背后的原因是为任何给定的单行创建一个类似“通用”的表解析器。 例如,我有这个表“tbl1”: +----+------------
我有一个列表,它可能包含也可能不包含重复的元素。给定另一个列表/元素集,我需要该列表中存在的所有唯一元素的列表。 Input: input_list = ['android', 'ios', 'and
需要编写一个算法来查找给定字符串在给定索引处的 Anagram,并按字典顺序排序。例如: Consider a String: ABC then all anagrams are in sorted
给定学生和铅笔的数量,假设学生有 154 名,铅笔有 93 名,如何用 Python 编写代码来获得比率。 输出:x:y 或者说给定两个数字的百分比并找出比率。 输出:x:y 最佳答案 import
给定学生和铅笔的数量,假设学生有 154 名,铅笔有 93 名,如何用 Python 编写代码来获得比率。 输出:x:y 或者说给定两个数字的百分比并找出比率。 输出:x:y 最佳答案 import
作为一名端到端自动化测试人员,我一直认为 Given、When、Then 语句(在使用 Cucumber 时合并到 Gherkin 语言中)应该只按 1.Given、2.When、3 的顺序出现.然后
我正在尝试以动态方式传递参数。我想使用 Perl 函数 given(){},但由于某种原因,我不能在其他任何东西中使用它。这就是我所拥有的。 print(given ($parity) { wh
我想在 cucumber 中测试以下功能。但是,我只想处理输入文件一次(以下功能中的@Given)。但是,它似乎每次都执行@Given 步骤。是否可以在以下功能中仅执行一次此@Given? @file
我想知道是否可以使用 given 参数来自 pytest 的 parametrize 函数。 示例: import pytest from hypothesis import given from h
在deep learning tutorials ,所有训练数据都存储在一个shared数组中,只有该数组的索引被传递给训练函数以切出一个小批量。我知道这允许将数据保留在 GPU 内存中,而不是将小块
我正在尝试运行以下代码: foreach my $k (keys %rec) { #switch for watchlist figures given ($k) { #line 93
我正在尝试在完全支持的情况下使用 GWT 规范,但是它的示例 official documentation有点简单。 在 SO 中搜索我发现了这个问题: Specs2 - How to define
我使用hypothesis 已经有一段时间了。我想知道如何重用 @given parts。 我有一些大约 20 行,我将整个 @given 部分复制到几个测试用例之上。 一个简单的测试例子 @give
我在运行 rspec 文件时不断收到错误: Failures:
让我们调用一个函数 function doSomethingAndInvokeCallback(callback){ // do something callback(); } 我可以
我是一名优秀的程序员,十分优秀!