I have a schema like below in mongodb
let reactions = [
{
messageId: 1,
reactions: [
{
"userid": "7212898122",
"reactionId": 2,
"date": "2022-05-12T18:55:49.943Z"
},
{
"userid": "8171763225",
"reactionId": 2,
"date": "2022-05-12T19:27:34.324Z"
},
{
"userid": "8782323232",
"reactionId": 3,
"date": "2022-05-12T18:55:49.943Z"
}
]
},
{
messageId: 2,
reactions: [
{
"userid": "7212898122",
"reactionId": 1,
"date": "2022-05-12T18:55:49.943Z"
},
{
"userid": "8171763225",
"reactionId": 2,
"date": "2022-05-12T19:27:34.324Z"
},
{
"userid": "8782323232",
"reactionId": 1,
"date": "2022-05-12T18:55:49.943Z"
}
]
}
]
I want to result like this
let result = [
{
messageId:1,
count:{
2:2,
3:1
}
},
{
messageId:1,
count:{
1:2,
2:1
}
}
]
Means two user reacted on reactionId 2 and One user reacted on reactionId 1, same like that for all messageId
I tried with group, but didn't exactly get result that I want. Please answer.
===================================
You can do something like:
$unwind
to separate reactions$group
both by messageId and reactionId, to get the count you want$group
by messageId to 'revert' the$unwind
and usek
andv
in the array to enable transforming into object.$project
to format as objectBut on mongodb the key should be string.
playground example