我已经定义了一个模型(通过使用sequelize-cli):
'use strict';
module.exports = function(sequelize, DataTypes) {
var Rating = sequelize.define('Rating', {
star_count: DataTypes.FLOAT,
details: DataTypes.TEXT
}, {
classMethods: {
associate: function(models) {
Rating.hasOne(models.Product);
}
}
});
return Rating;
};
但是,当我在db:migrate
后查询数据库中的Rating
时,我得到:
SELECT * from "Ratings";
id | star_count | details | createdAt | updatedAt
----+------------+---------+-----------+-----------
文档实际上与我上面所做的没有任何不同。我希望在这里看到一个product_id
字段。我做错了什么?
编辑:
Sequelize-CLI 在模型中创建一个名为index.js
的文件。它看起来像这样:
'use strict';
var fs = require('fs');
var path = require('path');
var Sequelize = require('sequelize');
var basename = path.basename(module.filename);
var env = process.env.NODE_ENV || 'development';
var config = require(__dirname + '/../config.js')[env];
var db = {};
if (config.use_env_variable) {
var sequelize = new Sequelize(process.env[config.use_env_variable]);
} else {
var sequelize = new Sequelize(config.database, config.username, config.password, config);
}
fs
.readdirSync(__dirname)
.filter(function(file) {
return (file.indexOf('.') !== 0) && (file !== basename) && (file.slice(-3) === '.js');
})
.forEach(function(file) {
var model = sequelize['import'](path.join(__dirname, file));
db[model.name] = model;
});
Object.keys(db).forEach(function(modelName) {
if (db[modelName].associate) {
db[modelName].associate(db);
}
});
db.sequelize = sequelize;
db.Sequelize = Sequelize;
module.exports = db;
这似乎是在调用associate
方法,该方法调用适当的函数(hasMany等),并根据文档应该建立正确的关系。本教程似乎证实了这一逻辑。
续集迁移将根据迁移文件创建更改,因此您需要指定引用外键,如下所示 https://stackoverflow.com/a/23035179/4583460
Sequelize.sync 命令将创建关联所需的任何附加密钥。因此,要么使用同步,要么提及更改迁移文件以包含外键引用。