如何在聚合中将多个字段合并到一个数组中?
How do a merge multiple fields into a single array in an aggregation?
我的数据在 "user.pk"
和 "usertags.user.pk"
中有用户主键。
[
{
_id: ObjectId("62015250cb18d3cadb32c38e"),
user: { pk: '7485070525' },
usertags: [ { user: { pk: '334777488' } } ]
},
{
_id: ObjectId("62015250cb18d3cadb32c38f"),
user: { pk: '334777488' },
usertags: [
{ user: { pk: '7485070525' } },
{ user: { pk: '271738610' } },
{ user: { pk: '31961021' } }
]
}
]
我希望将所有这些数据聚合到一个包含所有不同用户主键的列表中,因此上述数据的结果类似于 { _id: null, user_pks: [7485070525, 334777488, 271738610, 31961021] }
我尝试使用 $group
聚合,但我不知道如何合并 "user.pk"
和 "usertags.user.pk"
。有人可以帮我吗?
编辑:
这是我得到的最接近的,它将用户和用户标签放在单独的列表中。
db.collection.aggregate([
{ $unwind: "$usertags" },
{ $group: { _id: null, users: { $push: "$user.pk" }, usertags: {$push: "$usertags.user.pk" } } },
])
你可以这样做:
在这里测试 mongodb playground
db.collection.aggregate([
{
$group: {
_id: null,
user_pk: {
$push: "$user.pk"
},
user_sub_pk: {
$push: "$usertags"
}
},
},
// flattern array in user_sub_pk
{
$set: {
user_sub_pk: {
$reduce: {
input: "$user_sub_pk",
initialValue: [],
in: {
$concatArrays: [
"$$value",
"$$this"
],
},
},
},
},
},
{
$project: {
user_pks: {
$concatArrays: [
"$user_pk",
"$user_sub_pk.user.pk"
],
},
},
// remove duplicate items
{
"$project": {
"user_pks": {
"$setUnion": [
"$user_pks",
[]
]
}
}
}
}
])
更新:由@zrbecker重构
db.collection.aggregate([
{
$group: {
_id: null,
users: {
$push: "$user.pk"
},
usertags: {
$push: "$usertags.user.pk"
}
}
},
{
$project: {
users: {
$setUnion: [
"$users",
{
$reduce: {
input: "$usertags",
initialValue: [],
in: {
$concatArrays: [
"$$value",
"$$this"
]
}
}
}
]
}
}
}
])
我的数据在 "user.pk"
和 "usertags.user.pk"
中有用户主键。
[
{
_id: ObjectId("62015250cb18d3cadb32c38e"),
user: { pk: '7485070525' },
usertags: [ { user: { pk: '334777488' } } ]
},
{
_id: ObjectId("62015250cb18d3cadb32c38f"),
user: { pk: '334777488' },
usertags: [
{ user: { pk: '7485070525' } },
{ user: { pk: '271738610' } },
{ user: { pk: '31961021' } }
]
}
]
我希望将所有这些数据聚合到一个包含所有不同用户主键的列表中,因此上述数据的结果类似于 { _id: null, user_pks: [7485070525, 334777488, 271738610, 31961021] }
我尝试使用 $group
聚合,但我不知道如何合并 "user.pk"
和 "usertags.user.pk"
。有人可以帮我吗?
编辑: 这是我得到的最接近的,它将用户和用户标签放在单独的列表中。
db.collection.aggregate([
{ $unwind: "$usertags" },
{ $group: { _id: null, users: { $push: "$user.pk" }, usertags: {$push: "$usertags.user.pk" } } },
])
你可以这样做:
在这里测试 mongodb playground
db.collection.aggregate([
{
$group: {
_id: null,
user_pk: {
$push: "$user.pk"
},
user_sub_pk: {
$push: "$usertags"
}
},
},
// flattern array in user_sub_pk
{
$set: {
user_sub_pk: {
$reduce: {
input: "$user_sub_pk",
initialValue: [],
in: {
$concatArrays: [
"$$value",
"$$this"
],
},
},
},
},
},
{
$project: {
user_pks: {
$concatArrays: [
"$user_pk",
"$user_sub_pk.user.pk"
],
},
},
// remove duplicate items
{
"$project": {
"user_pks": {
"$setUnion": [
"$user_pks",
[]
]
}
}
}
}
])
更新:由@zrbecker重构
db.collection.aggregate([
{
$group: {
_id: null,
users: {
$push: "$user.pk"
},
usertags: {
$push: "$usertags.user.pk"
}
}
},
{
$project: {
users: {
$setUnion: [
"$users",
{
$reduce: {
input: "$usertags",
initialValue: [],
in: {
$concatArrays: [
"$$value",
"$$this"
]
}
}
}
]
}
}
}
])