如果日期在mongodb中为字符串格式,请使用$ gte和<e mongo运算符

时间:2018-08-02 06:52:26

标签: mongodb mongodb-query aggregation-framework

我在数据库中有一个{dob:"02-23-2000"}之类的dob字段。现在,我想对dob字段执行$gte&lte,其字符串格式如下:

db.panelists.count({"dob":{ '$gte': '08-02-1998', '$lte': '08-02-2003' }});

我总是将计数值设为零。

任何人都可以帮助我以相同的dob格式解决此查询。

1 个答案:

答案 0 :(得分:2)

您可以在mongodb 3.6

中尝试以下聚合

您可以使用$dateFromString聚合将dob从 字符串化为日期,然后轻松$count$match应用于文档。

1) $addFields

一起使用聚合
db.panelists.aggregate([
  { "$addFields": {
    "date": {
      "$dateFromString": { "dateString": "$dob", "format": "%m-%d-%Y" }
    } 
  }},
  { "$match": {
    "date": {
      "$gte": moment('08-02-1998').toDate(),
      "$lte": moment('08-02-2003').toDate()
    }
  }},
  { "$count": "count" }
])

2) 通过$expr 使用简单的查找查询

db.collection.find({
  "$expr": {
    "$and": [
      {
        "$gte": [
          { "$dateFromString": { "dateString": "$dob", "format": "%m-%d-%Y" }},
          ISODate("2000-02-22T00:00:00Z")
        ]
      },
      {
        "$lte": [
          { "$dateFromString": { "dateString": "$dob", "format": "%m-%d-%Y" }},
          ISODate("2000-02-24T00:00:00Z")
        ]
      }
    ]
  }
})

3) $expr

一起使用聚合
db.collection.aggregate([
  { "$match": {
    "$expr": {
      "$and": [
        {
          "$gte": [
            { "$dateFromString": { "dateString": "$dob", "format": "%m-%d-%Y" }},
            ISODate("2000-02-22T00:00:00Z")
          ]
        },
        {
          "$lte": [
            { "$dateFromString": { "dateString": "$dob", "format": "%m-%d-%Y" }},
            ISODate("2000-02-24T00:00:00Z")
          ]
        }
      ]
    }
  }}
])