Warning: file_get_contents(/data/phpspider/zhask/data//catemap/6/mongodb/11.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/flash/4.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Node.js Mongodb:在指定的时间内获取文档,而不考虑日期_Node.js_Mongodb_Mongodb Query_Aggregation Framework - Fatal编程技术网

Node.js Mongodb:在指定的时间内获取文档,而不考虑日期

Node.js Mongodb:在指定的时间内获取文档,而不考虑日期,node.js,mongodb,mongodb-query,aggregation-framework,Node.js,Mongodb,Mongodb Query,Aggregation Framework,假设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("

假设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") }
Iam有兴趣查找“日期”字段中的时间介于04:15和07:40之间的文档,而不考虑日期、月份和年份。间接查询必须匹配日期字段中的任何“YYYY-MM-DDT”

我的方法是,从节点查询假定的日期持续时间内的所有文档,然后对于与查询匹配的每个文档,将文档的“日期”字段与“yyy-MM-DDT”+“所需时间”进行比较(“yyy-MM-DD从每个文档的“日期字段”复制,通过转换为矩()进行比较,并获取月份、日期和年份”)使用moment.js模块

有没有办法直接查询得到相同的结果

注意:我使用nodejs连接到mongodb


这个问题的基础是。

这里的基本情况是用数学计算会议记录。注意,您已经对匹配的基本原则有了答案,但似乎在计算“分钟”部分时遇到了困难:

所以,当你把除数除以,你得到的表示仍然在
0-24
之间,但是有一个分数分量

或者直接使用日期数学,并通过以下方法清除重复:

无论哪种方式,它只是计算出部分组件,并将其添加到选择值中


如果你真的想定期查询这个,我强烈建议你设置一个单独的文档属性,只包含“时间”直接对其进行评估和查询,而不是每次都进行计算。

思维棒极了。如果有任何高级mongodb阅读材料推荐@Blakes Seven,那就太好了。@helloworld本身呢?阅读/搜索此处的问题和答案,或者直接在中搜索,可能会让您对其他可能的案例和解决方案有最广泛的了解。我真的只回答这里,但至少这给了我不同的人的问题和提示解决方案,否则我可能不会想到在白天。我同意@Blakes Seven。StackOverflow本身增加了很多知识。有谁能帮助解决一些相关的问题吗?
db.collection.aggregate([
    { "$redact": {
        "$cond": {
            "if": {
                "$and": [
                    { "$gte": [
                        { "$add": [
                            { "$hour": "$date" },
                            { "$divide": [{ "$minute": "$date" }, 60] }
                        ]},
                        4 + (15/60)
                    ]},
                    { "$lte": [
                        { "$add": [
                            { "$hour": "$date" },
                            { "$divide": [{ "$minute": "$date" }, 60] }
                        ]},
                        7 + (40/60)
                    ]}
                ]
            },
            "then": "$$KEEP",
            "else": "$$PRUNE"
        }
    }}
])
db.collection.aggregate([
    { "$redact": {
        "$cond": {
            "if": {
                "$let": {
                    "vars": {
                        "hours": {
                            "$divide": [
                                { "$mod": [
                                    { "$subtract": [ "$date", new Date(0) ] },
                                    1000 * 60 * 60 * 24
                                ]},
                                1000 * 60 * 60
                            ]
                        }
                    },
                    "in": {
                        "$and": [
                            { "$gte": [ "$$hours", 4 + (15/60) ] },
                            { "$lte": [ "$$hours", 7 + (40/60) ] }
                        ]
                    }
                }
            },
            "then": "$$KEEP",
            "else": "$$PRUNE"
        }
    }}
])