任何人都可以帮助使用 MySQL 命令来尝试选择表中日期/时间等于或大于现在 - 1 小时的所有记录吗?
现在我不能百分百确定这是描述这一点的最佳方式。
我基本上有带有日期/时间字段的记录(例如 2019-07-13 13:00:00),并且我想执行 MySQL select 来查找日期/时间为一小时前的所有记录。这是在事件发生一小时后触发函数。
我目前有这个,但不确定它是否完全正确:
SELECT * FROM database.table_name
WHERE (NOW() - INTERVAL 1 HOUR) >= 'date_of_event'
AND 'status' = 'Scheduled';
Run Code Online (Sandbox Code Playgroud)
任何想法都会很棒!
O. *_*nes 19
你们非常接近。在我看来,编写涉及日期/时间的 WHERE 条件的最易读的方法是:
WHERE date_of_event >= NOW() - INTERVAL 1 HOUR
Run Code Online (Sandbox Code Playgroud)
为什么?>=日期/时间值意味着“在”或“之后”。您需要能够查看您的查询代码并对其进行推理。该配方显然符合您的规格:
日期/时间等于或大于现在 - 1 小时?
但是:你说你想在时间一小时后触发一个事件。这可能意味着您想要选择
一小时或更早之前的日期/时间,即等于或小于现在 - 1 小时的日期/时间。
这就是你已经拥有的。但我会重写它
WHERE date_of_event <= NOW() - INTERVAL 1 HOUR
Run Code Online (Sandbox Code Playgroud)
<=意思是在或之前。
专家提示SELECT避免使用反引号,除非您的列或表与保留字(如或)具有相同的名称GROUP。避免使用保留字命名列或表。反引号看起来很像单引号,很容易混淆。
专业提示其中包含的日期/时间表达式=几乎永远不会成立,因为相等必须精确到秒或毫秒。所以要避免类似的情况date_of_event = NOW() - INTERVAL 1 HOUR。
| 归档时间: |
|
| 查看次数: |
16669 次 |
| 最近记录: |