MySQL-在两个日期之间从数据库中选择数据
我已将用户注册的日期保存为日期时间,例如 2011-12-06 10:45:36 。我已运行此查询,并且希望此项目 -2011-12-06
10: 45 : 36- 将被选择:
SELECT `users`.* FROM `users` WHERE created_at >= '2011-12-01' AND
created_at <= '2011-12-06'
但是不是。存在任何优雅的方式,该如何选择?我最初的想法是2011-12-06 + 1
,但是看起来不太好。
-
您的问题是日期的简短版本使用午夜作为默认设置。因此,您的查询实际上是:
SELECT users.* FROM users WHERE created_at >= '2011-12-01 00:00:00' AND created_at <= '2011-12-06 00:00:00'
这就是为什么您看不到10:45的记录的原因。
更改为:
SELECT users.* FROM users WHERE created_at >= '2011-12-01' AND created_at <= '2011-12-07'
您还可以使用:
SELECT users.* from users WHERE created_at >= '2011-12-01' AND created_at <= date_add('2011-12-01', INTERVAL 7 DAY)
它将以您要查找的相同时间间隔选择所有用户。
您可能还会发现BETWEEN运算符更具可读性:
SELECT users.* from users WHERE created_at BETWEEN('2011-12-01', date_add('2011-12-01', INTERVAL 7 DAY));
-
MySQL数据库在两个数据库之间同步
2021-02-02 关注 0 浏览112 1答案
-
在两个日期之间选择数据?
2021-02-02 关注 0 浏览108 1答案
-
MySQL:选择两个日期范围之间的所有数据
2021-06-15 关注 0 浏览105 1答案
-
比较两个 MySQL 数据库
2022-04-11 关注 0 浏览62 1答案
-
使用默认前缀从具有300个表的mysql数据库中选择
2021-03-12 关注 0 浏览109 1答案
-
比较两个MySQL数据库[关闭]
2021-02-02 关注 0 浏览148 1答案
-
MySQL-从多个具有相同结构但数据不同的表中选择数据
2021-02-02 关注 0 浏览116 1答案
-
使用MySQL在多个数据库中选择并插入
2021-04-20 关注 0 浏览153 1答案
-
从数据库中选择MappedSuperclass(hibernate)
2021-02-01 关注 0 浏览150 1答案
-
MySQL-从数据库中查找半径内的点
2021-02-02 关注 0 浏览204 1答案