gpt4 book ai didi

mysql - MongoDB : Query based on time in ISODate format

转载 作者:可可西里 更新时间:2023-11-01 10:26:25 25 4
gpt4 key购买 nike

假设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 运算符,用比较运算符表示时间范围之间的逻辑与 $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 - MongoDB : Query based on time in ISODate format,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33603864/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com