如何计算mongodb的时间戳差异(小时)?

时间:2016-12-14 09:21:12

标签: mongodb mongodb-query aggregation-framework

这是我的数据:

[
   {
       id: 1, 
       starttime: ISODate("2015-08-24T00:00:00.000Z"), 
       endtime: ISODate("2015-08-24T07:00:00.000Z")
   },
   {
       id: 2, 
       starttime: ISODate("2015-08-24T20:00:00.000Z"), 
       endtime: ISODate("2015-08-25T01:00:00.000Z")
   }
]

我可以创建一个mongodb查询来显示starttime和endtime的持续时间(或者在这种情况下是差异操作),结果如下:

[ {id:1, duration: 7}, {id: 2, duration: 5}]

请注意,时间戳可以具有不同的日期,因此$hour(聚合管道)可能不起作用。有人可以帮忙吗?谢谢

2 个答案:

答案 0 :(得分:7)

db.collectionname.aggregate([
  {$project: {
      duration: {$divide: [{$subtract: ["$endtime", "$starttime"]}, 3600000]}
  }}
])

答案 1 :(得分:1)

Mongo 5.0 release schedule 开始,$dateDiff 聚合运算符非常适合您产生两个日期之间差异的用例:

// { _id: 1, start: ISODate("2015-08-24T00:00:00Z"), end: ISODate("2015-08-24T07:00:00Z") }
// { _id: 2, start: ISODate("2015-08-24T20:00:00Z"), end: ISODate("2015-08-25T01:00:00Z") }
db.collection.aggregate([
  { $project:
    { duration:
      { $dateDiff: { startDate: "$start", endDate: "$end", unit: "hour" } }
    }
  }
])
// { "_id" : 1, "duration" : 7 }
// { "_id" : 2, "duration" : 5 }