我正在使用Node.js,Express和EJS开发一个小程序。
基本上我有一个后api路线如下:
app.post('/getJson', function (req, res) {
var jsonData = fetchData(req.body.selectpicker);
console.log('jsonData' + jsonData);
res.render('result.ejs', {
html: '<p>' + jsonData + '</p>'
});
});
fetchdata函数执行以下操作:
function fetchData(tableName)
{
var mysql = require('mysql');
var connection = mysql.createConnection({
host : 'xxxx',
user : 'xxxx',
password : 'xxxx!',
database : 'xxxxx',
port : 'xxxx'
});
connection.connect(function(err) {
console.log('error' + err);
// connected! (unless `err` is set)
});
var query = "SELECT * FROM " + tableName;
var data = [];
connection.query(query, function(err, rows, fields)
{
if (err) throw err;
data = rows;
console.log('The rows are: ', rows);
});
connection.end();
console.log('datsa' + data);
return data;
}
但我的问题是,当connection.query首次运行时,它不会进入回调函数,而是直接进入connection.end()。但是当它退出fetchData函数之后,然后运行回调函数,该函数在查询后返回行?
有什么想法吗?
我认为这可能与api的工作方式有关?
答案 0 :(得分:2)
connection.query
是异步的,因此您必须使用回调函数来处理查询结果。
以下是您的代码稍作修改:
API路线:
app.post('/getJson', function (req, res) {
fetchData(req.body.selectpicker, function(jsonata) {
console.log('jsonData' + jsonData);
res.render('result.ejs', {
html: '<p>' + jsonData + '</p>'
});
});
});
fetchdata函数:
function fetchData(tableName, done)
{
var mysql = require('mysql');
var connection = mysql.createConnection({
host : 'xxxx',
user : 'xxxx',
password : 'xxxx!',
database : 'xxxxx',
port : 'xxxx'
});
connection.connect(function(err) {
console.log('error' + err);
// connected! (unless `err` is set)
});
var query = "SELECT * FROM " + tableName;
connection.query(query, function(err, rows, fields)
{
if (err) throw err;
console.log('The rows are: ', rows);
done(rows);
});
connection.end();
}