导读:Mongodb是一个非关系型数据库,但是在实际应用中 , 我们经常需要进行关系查询 。本文将介绍mongodb如何进行关系查询 。
1. $lookup
$lookup操作符可以将多个集合进行关联查询 。它类似于SQL中的JOIN操作 。使用$lookup操作符时,必须指定from和localField参数,from参数表示要关联的集合名称,localField参数表示当前集合中要关联的字段名 。例如:
db.orders.aggregate([
{
$lookup:
{
from: "products",
localField: "product_id",
foreignField: "_id",
as: "order_details"
}
}
])
2. $graphLookup
$graphLookup操作符可以在具有父子关系的文档之间进行递归查询 。例如 , 在一个部门树形结构中,我们需要查询某个员工所在的所有上级部门,这时就可以使用$graphLookup操作符 。例如:
db.departments.aggregate([
$graphLookup:
from: "departments",
startWith: "$parent_dept_id",
connectFromField: "parent_dept_id",
connectToField: "_id",
【mongodb数据查询 mongodb 关系查询】as: "parent_departments"
3. $unwind
$unwind操作符可以将数组类型的字段展开成多条记录 。例如,我们需要查询每个订单中的商品信息,可以使用$unwind操作符展开商品数组 。例如:
{ $unwind: "$order_details" }
总结:以上就是mongodb关系查询的三种方法,$lookup操作符可以进行关联查询 , $graphLookup操作符可以进行递归查询 , $unwind操作符可以展开数组类型的字段 。在实际应用中,根据不同的需求选择不同的方法进行查询 。