一尘不染

如何访问RowDataPacket对象

mysql

我目前正在使用Node-webkit开发桌面应用程序。在此过程中,我需要从本地MySQL数据库获取一些数据。

查询工作正常,但我不知道如何访问结果。我将它们全部存储在一个数组中,然后将其传递给函数。在控制台中,它们如下所示:

RowDataPacket {user_id: 101, ActionsPerformed: 20}
RowDataPacket {user_id: 102, ActionsPerformed: 110}
RowDataPacket {user_id: 104, ActionsPerformed: 3}

这是查询结构:

var ret = [];
conn.query(SQLquery, function(err, rows, fields) {
    if (err)
        alert("...");
    else {
        for (var i of rows) 
            ret.push(i);
    }
    doStuffwithTheResult(ret);
}

如何在doStuffwithTheResult函数中检索此内容?值更重要,但是如果我也能得到键,那将是很好的。


阅读 1460

收藏
2020-05-17

共1个答案

一尘不染

原来它们是普通对象,您可以通过访问它们user_id

RowDataPacket实际上是创建对象的构造函数的名称,看起来像这样 new RowDataPacket(user_id, ...)。您可以通过访问其名称进行检查[0].constructor.name

如果结果是数组,则必须使用[0].user_id

2020-05-17