对象 Sequelize实例正在传递

object SequelizeInstance being pass

本文关键字:Sequelize 实例 对象      更新时间:2023-09-26

我很困惑,希望你能帮助我。 我正在节点中构建一个应用程序.js使用 express.js 并为我的 ORM 续集。 我使用以下代码创建了一个模型:

"use strict";
module.exports = function(sequelize, DataTypes) {
  var User = sequelize.define("User", {
    username: DataTypes.STRING
  });
  return User;
};

我的路线如下所示:

router.get('/', function (req, res) {
  models.User.findAll({ }).then(function(users) {
    res.render('index', {
      title: 'Project Insight',
      users: users
    });
  });
})

我正在为我的模板使用 EJS:

<ul>
    <% for(var i=0; i<users.length; i++) {%>
      <li><%= users[i] %></li>
    <% } %>
</ul>

我的观点中的输出是这样的:

[object SequelizeInstance]
[object SequelizeInstance]
[object SequelizeInstance]
[object SequelizeInstance]

我希望能够从数据库中提取名称,我对为什么会给出该结果感到困惑。 如果您需要我提供任何信息,请告诉我。 我对这一切都是陌生的,我处于停滞状态。 提前感谢您的所有帮助。

尝试更改 EJS 模板:

<ul>
    <% for(var i=0; i<users.length; i++) {%>
      <li><%= users[i].username %></li>
    <% } %>
</ul>
可能对

其他人有帮助:

model.findAll({where}).
  .then(res => {
    return res.map(row => {
      return row.dataValues
    });
  })

这将返回如下所示的对象列表:

[
  {
    column1: value1,
    column2: value2,
    ...
    columnN: valueN
  }
]