记一次关于 timestamp 无法检索时分秒的排坑记录
由于评论反馈 timestamp 是准确的,而我确实又测出了不准确,所以怀疑可能跟时区有关系,但我还没能验证这个问题,所以以下记录仅供参考,希望有知道的人能帮忙解答。
最近做一个项目需要精确地按照具体几点几分来检索数据库中的记录,我平常都是使用 laravel 数据库迁移中默认的 timestamp
来记录时间的,即 created_at
和 updated_at
的数据类型都是 timestamp
。
遇到这个需求我想当然的采用下面的这种方式来检索
Model::where('created_at', '>', '2020-01-01 12:35:06')->get();
然后发现这个检索只精确到日,会直接抛弃后面的时分秒,显然不满足我的需求。
于是我找到文档,发现里面有 whereDate
和 whereTime
,于是我自作聪明的组合起来,也就成了这样
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 协议》,转载必须注明作者和本文链接
推荐文章: