node如何做同步?

发布于 2022-08-31 09:13:11 字数 813 浏览 21 评论 0

nodejs搭配mysql数据库,代码如下:

    connection.query('select * from reply r,article a where r.aid = a.aid and parentId=""',function(err,ress){
        if(err) console.log(err);
        else
        {                           
            var j=0;
            for(var i=0;i<ress.length;i++){
                connection.query('select * from reply where parentId="'+ress[i].rid+'"',function(err,ress2){
                    if(err) console.log('查询失败');
                    else{
                        console.log(j);
                        ress[j++].reply = ress2;                                        
                    }
                })
        }
        console.log(ress);                          
        connection.end();
}

但是打印出来的结果reply属性为空,检测到位异步请求造成的,请问如果做同步?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

盗琴音 2022-09-07 09:13:11

async

async = require('async');
async.map(ress, function(item, callback) {
  connection.query('select * from reply where parentId="' + item.rid + '"', function(err, reply) {
    if (err) {
      return callback(err);
    }
    item.reply = reply;
    return callback(null, item);
  });
}, function(err, ress) {
  return console.log(ress);
});
软甜啾 2022-09-07 09:13:11

使用异步流程控制库就可以了
楼上推荐的是async
还有promise规范的Q,bluebire
还有国人写的thenjs
都可以解决你的问题

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文