我几天来一直在努力解决这个问题。我正在尝试返回ID列表引用的数据。
一个团队的JSON示例:
{
"Name":"Team 3",
"CaptainID":"57611e3431c360f822000003",
"CaptainName":"Name",
"DateCreated":"2016-06-20T10:14:36.873Z",
"Members":[
"57611e3431c360f822000003", //Same as CaptainID
"57611e3431c360f822000004" //Other members
]
}
这是路线:
router.route('/teams/:user_id')
.get(function (req, res) {
TeamProfile.find({
Members : {
$in : [req.params.user_id]
}
}).exec(function (err, teamProfiles) {
teamProfiles.forEach(function (teamProfile) {
UserProfile.find({
UserID : {
$in : teamProfile.Members.map(function (id) {
return id;
})
}
}, function (err, userProfiles) {
teamProfile.Members = userProfiles;
console.log(teamProfile); //will console log the remaining 2
})
.exec(function (err) {
res.json(teamProfile) //returns the first one only
})
})
});
})
我们的想法是通过使用ID获取最新数据来返回配置文件。
然而,它正在努力。它获取用户信息,但它不会返回代码中注释的所有团队+所有用户。共有3支球队。只返回第一个。如果我删除res.json(teamProfile)
,则控制台会记录所有3个团队。我想回归所有3支球队。
答案 0 :(得分:3)
这是因为在完成所有数据库操作之前调用了您的响应。因此,而不是每次使用async.forEach函数。安装异步模块
var async = require('async');
router.route('/teams/:user_id').get(function (req, res) {
TeamProfile.find({
Members : {
$in : [req.params.user_id]
}
}).exec(function (err, teamProfiles) {
async.forEach(teamProfiles,function (teamProfile,cb) {
UserProfile.find({
UserID : {
$in : teamProfile.Members.map(function (id) {
return id;
})
}
}, function (err, userProfiles) {
teamProfile.Members = userProfiles;
cb() // Callback
})
},function(){
res.json(teamProfiles)
})
});
})