添加与sequ​​elizejs模型的关联

时间:2017-02-28 07:12:42

标签: node.js postgresql associations sequelize.js

我已经定义了一个模型(使用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;
};

但是当我在Rating之后查询数据库中的db:migrate时,我得到了:

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方法,该方法调用the appropriate functions(hasMany等)并根据文档设置正确的关系。 This教程似乎证实了这一逻辑。

1 个答案:

答案 0 :(得分:1)

Sequelize migration将根据迁移文件创建更改,因此您需要使用引用指定外键,如下所示https://stackoverflow.com/a/23035179/4583460

Sequelize.sync命令将创建关联所需的任何aditional密钥。因此,使用同步或提及更改您的迁移文件以包含外键引用