MySQL select all the entries older than 10 days
大家好,我正在开发一个小脚本,它必须检查 MySQL 数据库中的条目是否至少早于 10 天。
该表有一个时间戳字段(这是我想使用的,但如果需要我可以更改它)。
实际上我正在使用这个 sql 字符串:
1
2 3 4 |
但我发现一些选定的条目”年轻”于 10 天,所以也许我弄错了什么。
这是正确的方法还是更好地通过 PHP(而不是 MySQL 查询)检查它?
提前致谢。
- 你可以发布一个例子吗?像 CURDATE() = X 和 DATE(last_update)=Y 一样,返回错误 Y 的示例是什么?
- 我不知道这一点,因为 last_update 字段每次都在”更新”,我得到错误行为的唯一线索是我有一个每次都会递增的”post count”字段,我发现一些 thise 计数增加太多
- 在 DB shell 中测试查询通常很有帮助。它通常不会改变数据。
older than 10 days 应该是 before 计算的日期。
1
2 |
- 嗯……你是对的……我想我搞砸了。
- 即使 last_update 是 dateTime 你也不需要 Date()
- 每次我谷歌我都想知道为什么它这么复杂。我的意思是在理想世界中的语法应该像 DATE>10d
- @ArsenIbragimov,因为它是一种”简单”查询语言。当他们制作它时,他们想创造一种人类可以轻松阅读的东西……显然失败了。
你也可以使用 DATEDIFF():
1
2 3 4 |
您还可以考虑您的查询并添加负间隔值:
1
2 3 4 |
SELECT *
FROM entries WHERE tag=‘$tag’ AND DATE(last_update) > DATE_SUB(CURDATE(), INTERVAL –10 DAY) |
来源:https://www.codenong.com/36545152/