NodeJS 中的嵌套 MongoDB 查询
Nested MongoDB query in NodeJS
我想 select 从 MongoDB 的两个集合中使用 NodeJS。我 select 来自 chat_messages
集合,有一个 userId 属性,我想在 ES6 Promise 的帮助下用用户名扩展结果对象。我试过这个:
db.collection("chat_messages")
.find({"room" : roomName})
.sort({"created" : 1})
.toArray()
.then(function(messages){
console.log(messages);
return Promise.all(messages.map(function(message){
return db.collection("chat_users")
.find({"id" : message.userId})
.limit(1)
.toArray()
.then(function(users){
message.userName = users[0].name;
});
}));
})
.then(function(messages){
console.log(messages);
})
.catch(function(error){
// ...
});
第一个 console.log 打印如下:
[
{
_id: 573b6f2af9172fd81252c520,
userId: 2,
...
},
{
_id: 57388bd913371cfc13323bbb,
userId: 1,
...
}
]
但是第二个看起来像这样:
[ undefined, undefined ]
我搞砸了什么?
Promise.all
returns 数据传递到承诺的解析函数中。这应该有效
db.collection("chat_messages")
.find({"room" : roomName})
.sort({"created" : 1})
.toArray()
.then(function(messages){
let promises = [];
messages.forEach(message => {
promises.push(new Promise(resolve => {
db.collection("chat_users")
.find({"id" : message.userId})
.limit(1)
.toArray()
.then(function(users){
message.userName = users[0].name;
resolve(message);
});
}));
});
return Promise.all(promises);
})
.then(function(messages){
console.log(messages);
})
.catch(function(error){
// ...
});
我想 select 从 MongoDB 的两个集合中使用 NodeJS。我 select 来自 chat_messages
集合,有一个 userId 属性,我想在 ES6 Promise 的帮助下用用户名扩展结果对象。我试过这个:
db.collection("chat_messages")
.find({"room" : roomName})
.sort({"created" : 1})
.toArray()
.then(function(messages){
console.log(messages);
return Promise.all(messages.map(function(message){
return db.collection("chat_users")
.find({"id" : message.userId})
.limit(1)
.toArray()
.then(function(users){
message.userName = users[0].name;
});
}));
})
.then(function(messages){
console.log(messages);
})
.catch(function(error){
// ...
});
第一个 console.log 打印如下:
[
{
_id: 573b6f2af9172fd81252c520,
userId: 2,
...
},
{
_id: 57388bd913371cfc13323bbb,
userId: 1,
...
}
]
但是第二个看起来像这样:
[ undefined, undefined ]
我搞砸了什么?
Promise.all
returns 数据传递到承诺的解析函数中。这应该有效
db.collection("chat_messages")
.find({"room" : roomName})
.sort({"created" : 1})
.toArray()
.then(function(messages){
let promises = [];
messages.forEach(message => {
promises.push(new Promise(resolve => {
db.collection("chat_users")
.find({"id" : message.userId})
.limit(1)
.toArray()
.then(function(users){
message.userName = users[0].name;
resolve(message);
});
}));
});
return Promise.all(promises);
})
.then(function(messages){
console.log(messages);
})
.catch(function(error){
// ...
});