【问题标题】:Getting error like "date is not defind" using nodejs with mogodb? datetime store as a timestamp in db使用带有 mongodb 的 nodejs 得到类似“日期未定义”的错误?日期时间存储为数据库中的时间戳
【发布时间】:2017-10-16 18:21:53
【问题描述】:

我正在使用带有 MongoDB 的 nodejs 获取数据。我在 MongoDB 中有对象。现在我要使用日期来获取数据,我提交的日期时间是一个时间戳。我想使用 MongoDB 获取从开始日期到结束日期的数据。 必须提示我想在预期的操作中打印日期。 这里我这是我的对象 =>

{
  "_id" : ObjectId("595be16ee04602135828e25c"),
  "Action" : "Comment",
  "datetime" : 1507099928000 // 4th oct 2017 convert date just for info here write
},
{
  "_id" : ObjectId("595be16ee04602135828e25c"),
  "Action" : "Comment",
   "datetime" : 1508139441716 // 16th oct 2017 convert date just for info here write
}
{
   "_id" : ObjectId("595be16ee04602135828e25c"),
   "Action" : "Comment",
   "datetime" : 1508139441716 // 16th oct 2017 convert date just for info here write
}
{
  "_id" : ObjectId("595be16ee04602135828e25c"),
  "Action" : "Like",
   "datetime" : 1508139441716 // 16th oct 2017 convert date just for info here write
 },

这是我的查询 =>

InstaAc.aggregate([
                    {
                        "$match": {
                            "_id": ObjectId("595be16ee04602135828e25c"),
                            "datetime": {
                           "$lte": 1508141028150, "$gte": 1507622568000
                            }
                        },
                            "Action": {
                                $in: ["Comment", "Like"]
                            }
                    },                                              
                    {
                        "$addFields": {
                            "datetime": {
                                "$add": [new Date(0), "$datetime"]
                            }
                        }
                    },
                        {
                            "$group": {
                                "_id": {
                                    "$dateToString": {
                                        "format": "%d-%m-%Y",
                                        "date": "datetime"
                                    }
                                },
                               "commentcount": { $sum: { $cond: [{ $eq: ["Action", "Comment"] }, 1, 0] } },
                                "likecount": { $sum: { $cond: [{ $eq: ["Action", "Like"] }, 1, 0] } },                                  
                            }
                        },                           
                        {
                            "$sort": {
                                "_id": 1
                            }
                        }
           ]).exec(function (err, data) {
            if (err) {
console.log(err); 
}
else {
console.log(data);        
}
 })

这是我上面的查询,我收到类似“日期未定义”的错误 拜托,任何人,知道如何解决这个问题,然后请帮助我。

我的例外 o/p =>

{ _id: '16-10-2017', commentcount: 2 ,likecount:1},

【问题讨论】:

    标签: node.js mongodb


    【解决方案1】:

    在运行查询之前,请创建一个日期对象并使用该对象而不是 new Date(0)。

    var myDate = new Date(0);
    

    在您的查询中

    "$addFields": {
                   "datetime": {
                   "$add": [myDate, "$datetime"]
                  }
    

    【讨论】:

    • 现在出现这样的错误“无法识别的管道阶段名称:'$addfields'”
    • @Edit 你用的是什么版本的Mongo?
    • 我正在使用对象而不是数组,因此使用此波日期是否会生成?你知道吗?
    • @Edit 老实说我不知道​​。我找到了这个,也许它可以帮助你。 stackoverflow.com/questions/43630875/…
    猜你喜欢
    • 2014-01-16
    • 1970-01-01
    • 2020-11-30
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2019-01-28
    • 2022-01-23
    相关资源
    最近更新 更多