node.js - 外键之间有一个关联

标签 node.js express sequelize.js

我是 ORM 的新手,目前正在使用 Express 了解 Sequelize 中的关联。我现在正在处理的问题是 hasOne 和belongsTo 方法以及在我的特定情况下应该如何调用和使用它们。

两个表之间存在简单的关系

CREATE TABLE rocks(
    rock_id BIGINT 
        NOT NULL AUTO_INCREMENT,
    name varchar(255)
        NOT NULL, 
    rock_mode_id BIGINT
        NOT NULL,   
    PRIMARY KEY (rock_id),
    FOREIGN KEY (rock_mode_id) REFERENCES rock_modes(rock_mode_id),
);

CREATE TABLE rock_modes (
    rock_mode_id BIGINT 
        NOT NULL AUTO_INCREMENT,
    rock_mode varchar(255),
    PRIMARY KEY (rock_mode_id)
);

因此,在 javascript 中,我尝试在定义模型并将其放置在“db”对象中之后执行此操作:
db.rock.hasOne(db.rock_mode, { foreignKey: 'rock_mode_id' });
db.rock_mode.belongsTo(db.rock, { foreignKey: 'rock_mode_id' });

然后,当我尝试渲染所有数据时:
test: function(req, res) {
    db.rock
    .findAll({include: 
    [{ model: db.rock_mode, on: 'rock_mode_id' }]})
    .success(
        function(rocks) {
            var rockString = "";
            var foundRockMode = "";
            rockString += "<h2>Rocks</h2>";
            for(var i = 0; i < rocks.length;i++){
                rockString += JSON.stringify(rocks[i])+"<br />";

            }
            res.render('test', {
                  title: 'A Page Called Test',
                  body: rockString
            });
        })
  },

当我运行页面时,我收到错误:
Error: ER_BAD_FIELD_ERROR: Unknown column 'rock_mode.createdAt' in 'field list'

我最终想要做的是能够访问 rock_modes 的“名称”字段并将其从岩石对象中打印出来。

最佳答案

createdAtupdatedAt 是默认添加到模型和相关表中的字段。将 Sequelize 附加到项目中时,您可以通过常规设置关闭此行为。

var sequelize = new Sequelize( 'dbname', 'dbuser', 'password', {
            host: 'hostname',
            define: {
                timestamps: false
            }
        });

以下是此问题的文档:

http://sequelizejs.com/docs/latest/models#definition
http://sequelizejs.com/docs/latest/models#configuration

顺便说一句:当您尝试获取具有相关关联(急切加载)的实体时,您不需要指定外键,因为它已在关联定义中指定。

关于node.js - 外键之间有一个关联,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21248442/

相关文章:

node.js - 如何在express中对api进行分组

javascript - 尝试将 promise 的 Angular 动态数组发送到表达服务器

sequelize.js - 我应该如何在没有 `include` 的情况下使用 graphql-sequelize 急切地加载关联?

node.js - 使用 Sequelize 查询自连接,包括相关记录

node.js - 使用 GraphicsMagic Node 将 EPS 转换为 PNG 不会保持透明度

node.js - KoaJS 与 Thunkify + Mongoose

node.js - Nodejs 或 ExpressJS Windows 身份验证

node.js - Sequelize,检查行是否存在并返回 bool 值

android - Azure -> Node.js 中的 Easy api -> 如何发送 Android 推送通知?

node.js - Sequelize : findAll and count associations at the same time