在MongoDB中,要删除特定分组的文档,可以使用$group
操作符结合$match
操作符和$unset
操作符来实现。
以下是一个示例:
db.collection.aggregate([
{
$group: {
_id: "$field_to_group_by",
documents: {
$push: "$$ROOT"
}
}
},
{
$match: {
_id: "group_value_to_delete"
}
},
{
$unwind: "$documents"
},
{
$replaceRoot: {
newRoot: "$documents"
}
},
{
$match: {
_id: {
$ne: "document_to_delete"
}
}
}
])
上述示例中,首先使用$group
操作符根据要分组的字段进行分组,并将每个分组的文档存储到一个数组中。然后使用$match
操作符选择要删除的特定分组。接下来,使用$unwind
操作符展开数组中的文档。然后使用$replaceRoot
操作符将展开的文档作为新的根文档。最后,使用$match
操作符排除要删除的特定文档。
请注意,上述示例仅适用于删除特定分组的文档,而不是删除整个分组。如果要删除整个分组,请使用$group
操作符结合$match
操作符和$group
操作符来实现。