gpt4 book ai didi

php - MongoDB查询日期

转载 作者:可可西里 更新时间:2023-11-01 09:37:06 27 4
gpt4 key购买 nike

如果日期相同,使用 $gt 查询将无法按预期工作。它更像是 $gte

但是如果我向查询参数添加 1 秒,那么它就可以工作了。

这是示例查询;

我有一个文档,它是 creation_date 1367414837 时间戳。

db.collection.find({creation_date : {'$gt' : new Date(1367414837000)}});

此查询与日期为 1367414837 的文档相匹配如果我增加查询时间戳,就像 1367414838 一样。它按预期工作。

我正在使用 mongo 控制台,但我在使用 MongoDate 的 php 中遇到了同样的问题

编辑:查询输出

db.collection.findOne({creation_date : {'$gt' : new Date(1367414837000)}});
{
"_id" : ObjectId("5181183543c51695ce000000"),
"action" : {
"type" : "comment",
"comment" : {
"id" : 74,
"post_id" : "174",
"owner_id" : "5",
"text" : "ne diyeyim lae :D",
"creation_date" : "2013-05-01 16:27:17"
}
},
"creation_date" : ISODate("2013-05-01T13:27:17.336Z"),
"owner" : {
"id" : "5",
"username" : "tylerdurden"
}
}

edit2:问题是 mongo 的 php 扩展。它被记录为“当文档被发送到数据库或从数据库发送时,任何超过毫秒的精度都会丢失。” http://php.net/manual/en/class.mongodate.php

我将查询参数增加了一秒作为周转解决方案。

最佳答案

Dates in BSON UNIX 日期是否等于自纪元以来的毫秒数;它们精确到毫秒。如果您插入(并尝试匹配)的时间精确到毫秒级别,则您尝试匹配的元素可能只比您查询的时间戳晚几毫秒,并且 $gt 可能按预期工作。 (例如,2013-05-01T13:27:17.001Z 确实晚于 2013-05-01T13:27:17Z。)

关于php - MongoDB查询日期,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16324389/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com