0

我有一个使用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;
4

0 回答 0