简体   繁体   English

Node.js中的多个相关SQL查询

[英]Multiple dependent SQL queries in Node.js

Im trying to build an app which requires that I make more than one query per view/controller. 我正在尝试构建一个应用程序,该应用程序要求每个视图/控制器进行多个查询。

Im trying to do the asynchronously using a nested structure, but the sql result comes up undefined in the inner closure. 我试图使用嵌套结构异步进行,但内部闭包中未定义sql结果。

This is the function Im using to do this: 这是Im用于执行此操作的功能:

var conn = db.config(mysql);

function run_queries(conn,callback) {

    conn.query(sql1, var1, function(err, res1) {

        if(err){ callback(err); return; }

        console.log(res1);     // RETURNS SUCCESSFULLY!

        conn.query(sql2, var2, function(err, res2) {

            if(err){ callback(err); return; }

            console.log(res2); // UNDEFINED :(

            callback(null, res2);

        });

    });

}

run_queries(conn,function(err, result){

    console.log(result);       // UNDEFINED :(

});

I have checked my SQL and it is without errors. 我已经检查了我的SQL,它没有错误。 If I swap sq1 with sq2, the outer closure returns the correct query for sq2. 如果我将sq1与sq2交换,则外部闭包将返回对sq2的正确查询。

The inner closure just isnt returning a query. 内部闭包只是不返回查询。

Async is a very useful for an asynchronous call. 异步对于异步调用非常有用。 You can make your code well maintained using an async module. 您可以使用异步模块使您的代码得到很好的维护。

Example of your code using async.parallel 使用async.parallel的代码async.parallel

var conn = db.config(mysql);
var async = require('async');

function run_queries(conn, cb) {


    async.parallel({

      res1: function (cb) {

        conn.query(sql1, var1, function (err, res1) {
          if (err) { cb(err) }
          else { cb(null, res1) }
        })
      },
      res2: function (cb) {

        conn.query(sql2, var2, function (err, res2) {
          if (err) { cb(err) }
          else { cb(null, res2) }
        })
      }
    },
    function (err, result) {
      if (err) { cb(err) }
      else { cb(null, result) }
    })

}

run_queries(conn, function (err, result) {
  console.log(result);       // UNDEFINED :(
  // GET OBJECT OF res1 AND res2
});

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM