如何解决递归嵌套数组-将查询应用于多个数组
{
"array": [
{
"date1": "date1","date2": "date2","childArray": [
{
"date1": "date1","childArray": [
{
"date1": "date1","date2": "date2"
}
]
}
]
}
]
}
我具有上述格式的文档-如果日期介于date1和date2之间,我需要能够查询给出日期并以递归方式获取所有内容。
可能需要一点帮助-我研究了聚合,并找到了一种可能通过聚合使此结构变平,然后应用查询的方法,但是我对此一无所知。
这是一个示例-childArray可以具有任意数量的深度,因此需要递归。
解决方法
您可以使用find
和$or
来做到这一点:
var date = ISODate("2020-08-12T23:45:00Z")
db.collection.find({
$or: [
{array: { $elemMatch:{
date1: {$lte: date},date2: {$gte: date}
}}},{"array.childArray": { $elemMatch:{
date1: {$lte: date},{"array.childArray.childArray": { $elemMatch:{
date1: {$lte: date},date2: {$gte: date}
}}}
]
})
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。