MySQL-在两个日期之间从数据库中选择数据

发布于 2021-02-02 16:29:10

我已将用户注册的日期保存为日期时间,例如 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,但是看起来不太好。

关注者
0
被浏览
81
1 个回答
  • 面试哥
    面试哥 2021-02-02
    为面试而生,有面试问题,就找面试哥。

    您的问题是日期的简短版本使用午夜作为默认设置。因此,您的查询实际上是:

    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));
    


推荐阅读
知识点
面圈网VIP题库

面圈网VIP题库全新上线,海量真题题库资源。 90大类考试,超10万份考试真题开放下载啦

去下载看看