同步数据库请求节点JS ORM

Synchronous DB requests Node JS ORM

本文关键字:JS ORM 节点 请求 数据库 同步      更新时间:2023-12-07

我需要用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);

您尝试执行的操作的上下文是什么?不能使异步操作同步。相反,您必须调用另一个函数来告诉程序异步操作已经完成。

例如,如果您正在响应客户端请求,一旦获得完整结果,就可以从回调中发送响应,例如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
})