我是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
的“名称”字段并从岩石对象中打印出来。
答案 0 :(得分:1)
createdAt
和updatedAt
是要添加到模型和相关表中的字段。将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
BTW:当您尝试获取具有相关关联的实体(急切加载)时,您不需要指定外键,因为它已在关联定义中指定。