假设Mongodb数据库中的示例文档如下:
{ "date" : ISODate("2015-11-09T05:58:19.474Z") }
{ "date" : ISODate("2014-10-25T07:30:00.241Z") }
{ "date" : ISODate("2015-11-30T15:24:00.251Z") }
{ "date" : ISODate("2012-01-10T18:36:00.101Z") }
预期:
{ "date" : ISODate("2015-11-09T05:58:19.474Z") }
{ "date" : ISODate("2014-10-25T07:30:00.241Z") }
我有兴趣找到“日期”字段中的时间在04:00到08:00之间的文件,无论日,月和年。间接查询必须匹配日期字段中的任何“YYYY-MM-DDT”。
我的方法是,在节点的假定持续时间内查询所有文档,然后对于与查询匹配的每个文档,将文档的“日期”字段与“yyyy-MM-DDT”+“required_time”进行比较( “YYYY-MM-DD从每个文档的”日期字段“复制,通过转换为moment()并使用moment.js模块获取月,日,年”来进行比较。
有没有办法查询直接得到相同的结果?
注意:我使用nodejs连接到mongodb
答案 0 :(得分:2)
一种方法是使用aggregation framework,特别是 $redact
运算符,该运算符根据文档及其子文档中的值剥离文档内容流。根据布尔表达式的结果,可以从流中删除文档,在检查其子文档之后将其包括在流中,或者只是将文档传递到流中。 $redact
背后的想法是简单地从流中删除敏感信息。
在您的情况下,条件表达式使用 $cond
运算符和 $and
布尔运算符来表示时间范围之间的逻辑AND使用比较运算符 $gt
和 $lt
。使用 $hour
日期运算符将date
字段的小时数作为0到23之间的数字返回。因此,您的最终聚合如下所示:
db.collection.aggregate([
{
"$redact": {
"$cond": {
"if": {
"$and": [
{ "$gt": [ {"$hour": "$date"}, 4] },
{ "$lt": [ {"$hour": "$date"}, 8] }
]
},
"then": "$$KEEP",
"else": "$$PRUNE"
}
}
}
])
示例输出:
/* 0 */
{
"result" : [
{
"_id" : ObjectId("56404450472fe25cc6b85886"),
"date" : ISODate("2015-11-09T05:58:19.474Z")
},
{
"_id" : ObjectId("56404450472fe25cc6b85887"),
"date" : ISODate("2014-10-25T07:30:00.241Z")
}
],
"ok" : 1
}