【发布时间】:2020-12-21 13:07:07
【问题描述】:
我的电子邮件消息应用程序使用如下所示的 DB 架构:
db={
"archives": [
{
"header": {
"subject": "message-1",
"message-id": "a"
}
},
{
"header": {
"subject": "Re:message-1",
"message-id": "b",
"reply-to": [
"a"
]
}
},
{
"header": {
"subject": "Re:message-1",
"message-id": "c",
"reply-to": [
"a"
]
}
},
{
"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"
}
}
]
我不知道如何计算每封起始电子邮件的回复数。在这个例子中:
- 消息 ID:A 有 2 个回复
- 消息 ID:D 有 1 个回复
我在 MongoDB 游乐场发布了这个示例:https://mongoplayground.net/p/H6IT0SfCqBp
【问题讨论】: