首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >MongoDB -仅在日期时间使用$lte数小时

MongoDB -仅在日期时间使用$lte数小时
EN

Stack Overflow用户
提问于 2018-08-02 13:31:21
回答 1查看 203关注 0票数 0

我的数据如下:

代码语言:javascript
复制
/* 1 */
{
    "_id" : ObjectId("5b62f97e3c2094eefa912aba"),
    "FietsID" : 1267,
    "Stad" : "Antwerpen",
    "Accelerometer" : 1.0,
    "Decibel" : null,
    "Datum" : ISODate("2017-06-06T05:45:06.000Z"),
    "Location" : {
        "type" : "Point",
        "coordinates" : [ 
            22.50891, 
            48.54121
        ]
    }
}

/* 2 */
{
    "_id" : ObjectId("5b62f97e3c2094eefa9128cc"),
    "FietsID" : 1971,
    "Stad" : "Antwerpen",
    "Accelerometer" : 1.0,
    "Decibel" : 55,
    "Datum" : ISODate("2017-06-11T18:17:21.000Z"),
    "Location" : {
        "type" : "Point",
        "coordinates" : [ 
            -38.23146, 
            -6.75194
        ]
    }
}

我想得到所有时间低于06:00,分贝大于90,和'Stad‘只有安特卫潘的数据。

我尝试过使用聚合$dateToString,但我只能使用一个参数进行匹配。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-08-02 13:39:50

您可以使用3.6中可用的$expr运算符来使用find中的聚合运算符,并使用$and来包含所有条件。

使用$hour从日期开始获取小时。

有点像

代码语言:javascript
复制
db.colname.find
({"$expr":{
  "$and":[
    {"$lte":[{"$hour":"$Datum"},6]},
    {"$gt":["$Decibel",90]},
    {"$gt":["$Stad","Antwerpen"]}
  ]
}})
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/51654977

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档