首先,我们可以使用 MongoDB 的 $lookup
操作符来查询嵌套的 JSON。
假设我们有一个名为 employees
的集合,其中每个文档都有一个名为 departments
的数组字段,我们想要查询每个员工的嵌套 JSON,我们可以使用以下查询语句:
db.employees.aggregate([
{
$unwind: "$departments"
},
{
$lookup: {
from: "departments",
localField: "departments",
foreignField: "_id",
as: "department"
}
},
{
$unwind: "$department"
},
{
$project: {
_id: 1,
name: 1,
departments: 1,
department: 1
}
}
])
这个查询语句使用了 $unwind
操作符来展开 departments
数组字段,然后使用 $lookup
操作符来查找嵌套的 departments
集合中的文档。最后,使用 $project
操作符来只返回 _id
、name
、departments
和嵌套的 department
字段。
如果查询结果中仍然有嵌套的 JSON,我们可以再次使用 $unwind
操作符来展开 department
字段,然后再次使用 $lookup
操作符来查找嵌套的 department
集合中的文档。
需要注意的是,如果嵌套的 JSON 层次很深,使用 $unwind
操作符可能会导致查询结果非常大,因此需要谨慎使用。
领取专属 10元无门槛券
手把手带您无忧上云