意图
在我的路由中建立与DB的连接,运行查询,捕获结果,并使其可以访问我的索引视图以在DOM中呈现。
问题
DB在控制台中成功连接并返回结果。但是,未能将此结果推入" finalResult"阵列。
var express = require('express');
var router = express.Router();
router.get('/', function(req, res) {
// Establish Connection with Database
var mysql = require('mysql');
var connection = mysql.createConnection({
host : '127.0.0.1',
user : 'root',
password : 'xxxxxxx',
database : 'my_db'
});
connection.connect();
// // Query and post result to console
connection.query('SELECT * FROM products', function(error, results, fields) {
if (error) throw error;
doSomething(results[0]);
});
connection.end();
var finalResult = ['hello'];
function doSomething(results) {
console.log(results.name);
finalResult.push(results.name);
}
console.log(finalResult);
// Render/make accessible to views
res.render('index', {
pageTitle: 'Home',
result: finalResult
});
});
module.exports = router;
doSomething(results[0]);
成功将结果推送到doSomething()
函数,因为console.log(results.name)
返回正确的查询结果。 finalResult.push(results.name)
发生问题,因为console.log(finalResult)
仅返回带有" hello"的数组。什么时候应该"你好"加上查询结果。
答案 0 :(得分:1)
请注意,当您从 mysql 模块查询数据库时是同步的(查询将函数作为参数 - 回调)。这意味着您不能将结果值作为查询函数之外的变量。尝试使用 async/await 或 promise 来获取返回值。
答案 1 :(得分:0)
在将新数据推送到finalResult数组后,尝试在doSomething函数中编写console.log(finalResult)。
我认为你只看到" helo"因为console.log(finalResult)在doSomething函数完成之前执行(在将数据添加到finalResult数组之前)。