同步数据库请求节点JS ORM

时间:2016-04-03 19:31:50

标签: javascript node.js postgresql node-orm2

我需要使用DB中的值填充数组,然后才返回它,那么如何才能使这个同步

   var convs = Array;
    User.find({token: token}).first(function(err, user) {
          ConversationData.find({user_id: 1}).each().forEach(function(convData) {
            ConversationData.count({conversation_id: convData.conversation_id}, function(err, count) {
              if(count == 2) {
                var user2;
                console.log(convData.user_id);
                ConversationData.find({user_id: 2, conversation_id: convData.conversation_id}).first(function(err, usr) {
                  user2 = usr;
                });
                Message.find({conversation: convData.conversation_id}, [ "createdAt", "Z" ]).first(function(err, msg){
                  convs[convData.id].conversation = convData.id;
                  convs[convData.id].lastMessage = msg.content;
                  convs[convData.id].lastMessageDate = msg.createdAt;
                  convs[convData.id].title = user2.name + " " + user2.name;
                  convs[convData.id].avatar = user2.avatar;
                });
              } else {
                console.log('COUNT = ' + count);
              }
            });
          });
console.log(convs);

1 个答案:

答案 0 :(得分:0)

您尝试做什么的背景是什么?您无法使异步操作同步。相反,您必须调用另一个函数来告诉程序异步操作已完成。

例如,如果您要回复客户端请求,则可以在获得完整结果后从回调中发送回复,例如: response.send(result);否则,您可以调用done()函数或类似函数来传递结果。

要在代码中表示最终结果,并从嵌套回调中解脱出来,请考虑使用Promises替换回调函数。例如

return User.find({token: token}).then(function(userData){
    return Conversation.find({id: userData.id});
}).then(function(conversationData){
    return Message.find({conv_id: conversationData.id}); //or response.send(conversationData) etc
})