记一次关于 timestamp 无法检索时分秒的排坑记录

由于评论反馈 timestamp 是准确的,而我确实又测出了不准确,所以怀疑可能跟时区有关系,但我还没能验证这个问题,所以以下记录仅供参考,希望有知道的人能帮忙解答。


最近做一个项目需要精确地按照具体几点几分来检索数据库中的记录,我平常都是使用 laravel 数据库迁移中默认的 timestamp 来记录时间的,即 created_atupdated_at 的数据类型都是 timestamp

遇到这个需求我想当然的采用下面的这种方式来检索

Model::where('created_at', '>', '2020-01-01 12:35:06')->get();

然后发现这个检索只精确到日,会直接抛弃后面的时分秒,显然不满足我的需求。

于是我找到文档,发现里面有 whereDatewhereTime,于是我自作聪明的组合起来,也就成了这样

Model::whereDate('created_at', '>', '2020-01-01')->whereTime('created_at', '>', '12:35:06')->get();

然后发现结果也不对,这里解析出来的结果是日期大于 2020-01-01 且时间大于 12:35:06,并不是我要的日期时间大于 2020-01-01 12:35:06

后来我就发了一个帖子来询问这个问题,得到的答案跟我一开始想的一样,但是我却得不到这样的结果。

这时候我加了个群,想着找个人聊聊吧,还真找到了,在群里得知,timestamp 有坑,得换成 datetime,我试了下,果然,苍天啊,我要的结果终于出现了。

我也不知道 laravel 为什么要用 timestamp,不知道替换成 datetime 是不是最好的答案,不过问题暂时解决了,写这一篇文章给后面有需要的人提供一个解决方案吧,如果有大神知道这里面的蹊跷,希望能帮忙解释下。

本作品采用《CC 协议》,转载必须注明作者和本文链接
《L02 从零构建论坛系统》
以构建论坛项目 LaraBBS 为线索,展开对 Laravel 框架的全面学习。应用程序架构思路贴近 Laravel 框架的设计哲学。
《L01 基础入门》
我们将带你从零开发一个项目并部署到线上,本课程教授 Web 开发中专业、实用的技能,如 Git 工作流、Laravel Mix 前端工作流等。
讨论数量: 4

file

file 没发现有什么问题啊

5年前 评论
Janpun (楼主) 5年前

是不是时区问题呢

5年前 评论
DotO 5年前
DotO 5年前
Janpun (楼主) 5年前
lddtime (作者) 5年前
Epona

第一种写法是没问题的, 至于没找到想要的结果,就得具体问题 具体分析了😂

5年前 评论

建议你查一下 ORM 生成的 SQL 具体是什么,如果 config/app.php 里面的 timezone 没有问题的话,应该也不是时区问题

5年前 评论