我有一个使用inquirer 和mysql2 的nodejs 项目。我创建了一个类来将我的 sql 查询存储为函数,以便能够将这些查询与查询器一起使用。当我运行以下函数时,当我返回管理器数组时,我得到未定义。但是当我 console.log 数组时,一切都按预期显示。这是我的功能:
viewManagers() {
const sql = `SELECT CONCAT(first_name, ' ', last_name) AS manager FROM employee WHERE manager_id IS NULL;`;
db.query(sql, (err, rows) => {
if (err) throw err;
const managers = [];
for (let i = 0; i < rows.length; i++) {
managers.push({ name: rows[i].manager, value: i+1 });
}
managers.push({ name: "None", value: null });
return managers;
});
}
我这样称呼它来测试它,
const query = new Query();
console.log(query);
如果我将 viewManagers 函数中的 return 语句更改为 aconsole.log(managers);
然后在控制台中返回管理器数组。我怎样才能成功地返回这个数据,所以它不是未定义的?我希望能够返回它,然后从另一个函数中调用这个函数。我也尝试使用 promisify 并得到相同的结果:
const db = require('../db/connection');
const util = require('util');
const query = util.promisify(db.query).bind(db);
class Query {
async viewManagers() {
try {
const sql = `SELECT CONCAT(first_name, ' ', last_name) AS manager FROM employee WHERE manager_id IS NULL;`;
const rows = await query(sql);
const managers = [];
for (let i = 0; i < rows.length; i++) {
managers.push({ name: rows[i].manager, value: i+1 });
}
managers.push({ name: "None", value: null });
return managers;
} finally {
db.end();
}
}
}
module.exports = Query;