如何解决如何在 MongoDB 中进行嵌套计数?
我有一个电子邮件应用程序,它使用如下所示的数据库架构:
db={
"archives": [
{
"header": {
"subject": "message-1","message-id": "a"
}
},{
"header": {
"subject": "Re:message-1","message-id": "b","reply-to": [
"a"
]
}
},"message-id": "c",{
"header": {
"subject": "message-2","message-id": "d"
}
},{
"header": {
"subject": "Re:message-2","message-id": "e","reply-to": [
"d"
],}
}
]
}
我可以像这样列出所有起始电子邮件(那些没有 reply-to
标签的):
db.archives.aggregate([
{
$match: {
"header.reply-to": {
$exists: false
}
}
}
])
这表明只有 message-id: a
和 message-id: d
是起始电子邮件:
[
{
"_id": ObjectId("5a934e000102030405000000"),"header": {
"message-id": "a","subject": "message-1"
}
},{
"_id": ObjectId("5a934e000102030405000003"),"header": {
"message-id": "d","subject": "message-2"
}
}
]
我无法弄清楚如何获得对每封起始电子邮件的回复计数。在这个例子中:
- Message-ID:A 有 2 条回复
- 消息 ID:D 有 1 个回复
我在 MongoDB 游乐场上发布了这个示例:https://mongoplayground.net/p/H6IT0SfCqBp
解决方法
-
$lookup
具有相同的集合,将header.message-id
作为 localField 传递,将header.reply-to
作为foreignField 传递 -
$size
获取repliesCount
数组中的总元素
db.archives.aggregate([
{ $match: { "header.reply-to": { $exists: false } } },{
$lookup: {
from: "archives",localField: "header.message-id",foreignField: "header.reply-to",as: "repliesCount"
}
},{ $addFields: { repliesCount: { $size: "$repliesCount" } } }
])
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。