PHP   发布时间:2022-04-04  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了php-MongoDB查询日期大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

如果日期相同,则使用$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

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

解决方法:

UNIX日期为Dates in BSON,等于自纪元以来的毫秒数;他们精确到毫秒.如果您要插入(并尝试匹配)的时间精确到毫秒级,则您要匹配的元素可能比您查询的时间戳晚几毫秒,并且$gt可能有效如预期的那样. (例如,2013-05-01T13:27:17.001Z确实晚于2013-05-01T13:27:17Z.)

大佬总结

以上是大佬教程为你收集整理的php-MongoDB查询日期全部内容,希望文章能够帮你解决php-MongoDB查询日期所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签: