记一次关于 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 协议》,转载必须注明作者和本文链接
《L05 电商实战》
从零开发一个电商项目,功能包括电商后台、商品 & SKU 管理、购物车、订单管理、支付宝支付、微信支付、订单退款流程、优惠券等
《L03 构架 API 服务器》
你将学到如 RESTFul 设计风格、PostMan 的使用、OAuth 流程,JWT 概念及使用 和 API 开发相关的进阶知识。
讨论数量: 4

file

file 没发现有什么问题啊

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

是不是时区问题呢

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

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

4年前 评论

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

4年前 评论

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!