根据日期返回查询

时间:2012-01-12 13:22:13

标签: mongodb

我在mongodb中有这样的数据

{ 
    "latitude" : "", 
    "longitude" : "", 
    "course" : "", 
    "battery" : "0", 
    "imei" : "0", 
    "altitude" : "F:3.82V", 
    "mcc" : "07", 
    "mnc" : "007B", 
    "lac" : "2A83", 
    "_id" : ObjectId("4f0eb2c406ab6a9d4d000003"), 
    "createdAt" : ISODate("2012-01-12T20:15:31Z") 
}

如何查询db.gpsdatas.find({'createdAt': ??what here??}),以便从数据库中将上述数据结果返回给我?

8 个答案:

答案 0 :(得分:329)

您可能想要进行范围查询,例如,在给定日期之后创建的所有项目:

db.gpsdatas.find({"createdAt" : { $gte : new ISODate("2012-01-12T20:15:31Z") }});

我正在使用$gte(大于或等于),因为这通常用于仅限日期的查询,其中时间组件为00:00:00。

如果您确实想要找到一个等于另一个日期的日期,则语法为

db.gpsdatas.find({"createdAt" : new ISODate("2012-01-12T20:15:31Z") });

答案 1 :(得分:15)

如果您想在该日期的任何地方获取物品,则需要比较两个日期

您可以像这样在第一个日期之外创建两个日期,以获得当天的开始和一天结束。

var startDate = new Date(); // this is the starting date that looks like ISODate("2014-10-03T04:00:00.188Z")

startDate.setSeconds(0);
startDate.setHours(0);
startDate.setMinutes(0);

var dateMidnight = new Date(startDate);
dateMidnight.setHours(23);
dateMidnight.setMinutes(59);
dateMidnight.setSeconds(59);

### MONGO QUERY

var query = {
        inserted_at: {
                    $gt:morning,
                    $lt:dateScrapedMidnight
        }
};

//MORNING: Sun Oct 12 2014 00:00:00 GMT-0400 (EDT)
//MIDNIGHT: Sun Oct 12 2014 23:59:59 GMT-0400 (EDT)

答案 2 :(得分:12)

刚刚使用Node v0.12.7和v4.4.4在Mongo v3.2.3中实现了类似的东西并使用了:

{ $gte: new Date(dateVar).toISOString() }

我传入ISODate(例如2016-04-22T00:00:00Z),这适用于带或不带toISOString函数的.find()查询。但是当在.aggregate()$ match查询中使用它时,它不喜欢toISOString函数!

答案 3 :(得分:10)

如果你想在过去5分钟内获得所有新东西,你就必须做一些计算,但这并不难......

首先在要匹配的属性上创建一个索引(包括排序方向-1表示降序,1表示升序)

db.things.createIndex({ createdAt: -1 }) // descending order on .createdAt

然后查询在最后5分钟(60秒* 5分钟)内创建的文档....因为javascript' s .getTime()在您将其用作输入之前,需要多次返回1000毫秒new Date()构造函数。

db.things.find({
        createdAt: {
            $gte: new Date(new Date().getTime()-60*5*1000).toISOString()
         }
     })
     .count()

new Date(new Date().getTime()-60*5*1000).toISOString()的说明如下:

首先我们计算" 5分钟前":

  1. new Date().getTime()以毫秒为单位提供当前时间
  2. 我们希望从中减去5分钟(以毫秒为单位):5*60*1000 - 我只需乘以60秒即可轻松更改。如果我想要2小时(120分钟),我可以将5更改为120
  3. new Date().getTime()-60*5*1000给了我们1484383878676(5分钟前的ms)
  4. 现在我们需要将它提供给new Date()构造函数以获取MongoDB时间戳所需的ISO字符串格式。

    1. { $gte: new Date(resultFromAbove).toISOString() }(mongodb .find()查询)
    2. 由于我们无法变量,我们一次性完成所有操作:new Date(new Date().getTime()-60*5*1000)
    3. ...然后转换为ISO字符串:.toISOString()
    4. new Date(new Date().getTime()-60*5*1000).toISOString()向我们提供2017-01-14T08:53:17.586Z
    5. 当然,如果您使用node-mongodb-native驱动程序,这对变量来说会更容易一些,但这可以在mongo shell中使用,这是我通常用来检查的东西。

答案 4 :(得分:4)

您也可以尝试:

{
    "dateProp": { $gt: new Date('06/15/2016').getTime() }
}

答案 5 :(得分:2)

如果您使用猫鼬,

try {
  const data = await GPSDatas.aggregate([
    {
      $match: { createdAt : { $gt: new Date() }
    },
    {
      $sort: { createdAt: 1 }
    }
  ])
  console.log(data)

} catch(error) {
    console.log(error)
}

答案 6 :(得分:0)

查找特定日期:

db.getCollection('CollectionName').find({"DepartureDate" : new ISODate("2019-06-21T00:00:00.000Z")})

找到较大的gte或较小的lt

db.getCollection('CollectionName').find({"DepartureDate" : { $gte : new ISODate("2019-06-11T00:00:00.000Z") }})

按范围查找:

db.getCollection('CollectionName').find({ 
    "DepartureDate": { 
        $lt: new Date(), 
        $gte: new Date(new Date().setDate(new Date().getDate()-15))
      } 
    })

答案 7 :(得分:0)

如果您想从日期时间获取记录,可以使用以下命令:

(mongodbCompass 3.6.8 with PyMongo)

mongo.db.collection.aggregate([{"$match":{"object.object.key":{"$gte":ISODate('2021-01-27T00:00:00Z').toISOString()}}}])

db.collection.find({"object.object.key":{"$gte":ISODate('2021-01-27T00:00:00Z').toISOString()}})