mysql - 如何在nodejs回调函数中从mysql获取完整数据

标签 mysql node.js express pug

var mysql = require("mysql");
var connection = mysql.createConnection({
    host: 'localhost',
    user: 'root',
    password: '',
    database: 'nodejs'
});

exports.players_list = function(req, res) {
    
    var data = {title: "", res: {}};
    if (authenticate(req, res)) {

        results_aaa(function(result) {
            console.log(result);
            res.render('players/players', {title: 'Players List', res: result});
        });
    } else {
        req.session.error = 'Please login to continue.';
        res.redirect('/login');
    }
};

function results_aaa(callback) {
    teams(function(res) {
        callback(res)
    });
}

function teams(callback) {
    var query = connection.query("select * from team", function(err, result, fields) {
        for (var index in result)
        {
            players(result[index].id, function(results) {
                callback(results);
            });
        }
    });
}

function players(id, callback) {
    query("SELECT * FROM players where team = " + id, function(results) {
        callback(results);
    });
}

function query(sql, callback) {
    connection.query(sql, function(error, results, fields) {
        callback(results);
    });
}

我正在尝试将特定团队的数据与团队成员分组。 我得到了部分输出。但是如果我使用 console.log(),我可以在控制台中看到整个输出

控制台中的输出如下所示。

Express server listening on port 8081
[ { id: 2, player_name: 'Virat Kohli', team: '1' },
  { id: 4, player_name: 'A B DeVilliers', team: '1' },
  { id: 6, player_name: 'Chris Gayle', team: '1' } ]
GET /players 200 162ms - 638
[ { id: 7, player_name: 'Ajinkya Rahane', team: '2' },
  { id: 8, player_name: 'Shane Watson', team: '2' },
  { id: 9, player_name: 'Stuart Binny', team: '2' },
  { id: 10, player_name: 'Karun Nair', team: '2' },
  { id: 11, player_name: 'Sanju Samson', team: '2' } ]
[ { id: 1, player_name: 'Virender Sehwag', team: '3' },
  { id: 3, player_name: 'David Miller', team: '3' },
  { id: 5, player_name: 'Shaun Marsh', team: '3' } ]

只有 ID 为 1 的团队出现在 jade View 中。

所遵循的程序是否正确。我是 Node.js 新手。

提前致谢:)

最佳答案

这是因为您在收到第一个回调(即 team1 结果)之后、在收到其他两个(第 2 队和第 3 队结果)之前发送响应。

在函数 team() 中,使用

if(index == result.length-1) { callback(results); }

而不仅仅是

callback(results);

for循环内。

关于mysql - 如何在nodejs回调函数中从mysql获取完整数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31625714/

相关文章:

mysql - SQL 查询 Join with datetime inside

php - 从逗号分隔值 mysql 和数组中查找并选择

javascript - 在 Node.js 和 Delphi 应用程序之间交换消息

node.js - git 通过 ssh 推送时如何更改用户身份?

node.js - 在哪里检索音频文件? — Arduino-光子项目

php - 导入 mySql 数据库后,我的数据库文本中有奇怪的字符 : Ã, Á, œ, â€

mysql 系统变量 table_type 不起作用

node.js - 是否可以从express 渲染另一个express 应用程序?

node.js - Sequelize,实例化后如何更改值?

javascript - 如何确定 Express 应用程序与 MongoDB 的连接是否真正打开?