MySQL 返回日期/时间现在减去 1 小时的记录?

标签 mysql datetime

任何人都可以帮助使用 MySQL 命令来尝试选择表中日期/时间等于或大于现在 - 1 小时的所有记录吗?

现在我不是 100% 确定这是描述这一点的最佳方式。

我基本上有带有日期/时间字段的记录(例如 2019-07-13 13:00:00),我想执行 MySQL 选择以查找日期/时间为一小时前的所有记录。这是在事件发生一小时后触发功能。

我目前有这个,但不确定它是否完全正确:

SELECT * FROM database.table_name
WHERE (NOW() - INTERVAL 1 HOUR) >= 'date_of_event'
AND 'status' = 'Scheduled';

任何想法都会很棒!

最佳答案

你很亲近。在我看来,编写涉及日期/时间的 WHERE 条件的最易读的方式是:

 WHERE date_of_event >= NOW() - INTERVAL 1 HOUR

为什么? >=对于日期/时间值意味着在或之后。您需要能够查看您的查询代码并对其进行推理。该配方明确符合您的规范:

a date/time equal to or more than now - 1hour?



但是 :你说你想在时间后一小时触发一个事件。这可能意味着你想要选择

a date/time one hour or more ago, that is a date/time equal to or less than now - 1 hour.



这就是你已经拥有的。但我会重写它
WHERE date_of_event <= NOW() - INTERVAL 1 HOUR
<=表示在或之前。

专业提示 避免使用反引号,除非您的列或表与保留字(如 SELECT)同名。或 GROUP .避免使用保留字命名列或表。反引号看起来很像单引号,很容易混淆。

专业提示 带有 = 的日期/时间表达式在它们中几乎从来没有出现过,因为相等必须是精确的,精确到秒或毫秒。所以要避免像 date_of_event = NOW() - INTERVAL 1 HOUR 这样的情况.

关于MySQL 返回日期/时间现在减去 1 小时的记录?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59578211/

相关文章:

c# - 合并两个数据库表的 LINQ 代码?

php - 如何在mysql中获得加仑、毫升和升的总和

MySQL DATETIME 到 TIMESTAMP 转换

python - 类型错误 : an integer is required python

python - 通过 datetime.date 列表选择数据帧行(datetimeindex)

mysql - 在 MySQL 中,是否可以从 GROUP_CONCAT 返回超过 1024 个字符

mysql - 同一张表上的两个 select 语句并获取 Count(*)

python - Web.py db.insert() 不插入行

java - 在java中将多个位置的本地日期时间转换为UTC

.net - 为什么 DateTime.ParseExact 不使用尾随 Z 解析 UTC 格式?