- 34
- 0
- 现在有这样的数据结构,比如在集合 class 里有一条
{
_id:ObjectId(123456789...),
number:10,
students:[
{
studentId:ObjectId(123456789...)/* 这个是student集合的id */
},
{
studentId:ObjectId(123456789...)/* 这个是student集合的id */
},
...
],
teacher:ObjectId(123456789...),
}
- student 集合的数据结构是
{
_id:ObjectId(123456789...);
name:'zhangsan',
age:20,
}
- 现在的需求是查询class的时候把student也取出来,这样就要关联查询,我用的是pipeline的$lookup,但是好像只能查询class下一级的属性,比如关联查询teacher
db.class.aggregate([
{
$lookup:
{
from: "teacher",
localField: "teacher",
foreignField: "_id",
as: "teacher"
}
}
])
- 但是student下的studentId,就无法实现,我试过
db.class.aggregate([
{
$unwind:students,
},
{
$lookup:
{
from: "student",
localField: "students.studentId",
foreignField: "_id",
as: "student",/* 这里可能不对,但是不影响把student取出来 */
}
}
])
- 希望有大佬可以解惑!不能改数据结构
0
打赏
收藏
点击回答
网站公告
- 扫一扫访问手机版
回答动态

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器更新之后。服务器里面有部分玩家要重新创建角色是怎么回事啊?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题函数计算不同地域的是不能用内网吧?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题ARMS可以创建多个应用嘛?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题在ARMS如何申请加入公测呀?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题前端小程序接入这个arms具体是如何接入监控的,这个init方法在哪里进行添加?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器刚到期,是不是就不能再导出存档了呢?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器的游戏版本不兼容 尝试更新怎么解决?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器服务器升级以后 就链接不上了,怎么办?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器转移以后服务器进不去了,怎么解决?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器修改参数后游戏进入不了,是什么情况?预计能赚取 0积分收益
- 回到顶部
- 回到顶部

