mysql - 蒙戈数据库 : Query based on time in ISODate format

标签 mysql node.js mongodb date momentjs

假设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”。

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

有什么方法可以直接查询得到相同的结果吗?

注意:我使用nodejs连接到mongodb

最佳答案

一种方法是使用 aggregation framework ,特别是 $redact 运算符,根据文档及其子文档中的值剥离文档内容流。根据 bool 表达式的结果,可以从流中修剪文档,在检查其子文档后将其包含在流中,或者直接将其完整传递到流中。 背后的想法$redact 是为了轻松地从流中删除敏感信息。

在您的情况下,条件表达式使用 $cond 运算符和 $and bool 运算符,用比较运算符表示时间范围之间的逻辑 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
}

关于mysql - 蒙戈数据库 : Query based on time in ISODate format,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33603864/

相关文章:

javascript - Node.js JavaScript 语法

django - Djongo 重新定义 ArrayModelField 的结构

php - Codeigniter 删除

mysql - 如何在mysql中获取一行中的多个项目?

javascript - 使用损坏的文件编辑 chrome 扩展问题

node.js - 慢速查询会阻塞快速查询,直到执行慢速查询为止 : MongoDB with NodeJs driver

php - 为什么这个简单的 "INSERT INTO"查询不起作用

mysql - sql每月选择前5名

arrays - MongoDB:匹配数组元素的计数

MongoDB - 获取不同级别字段之间的$max