Ассоциация моделей в sequelize [erro] {this.name} .hasMany вызывается с чем-то, что не является подклассом Sequelize.Model - PullRequest
0 голосов
/ 07 марта 2020

Я попробую создать проект и использовать node.js + sequelize, в проекте есть две модели Fator и Sub_fator. У них есть связь 1: N, но при создании fator возвращается ошибка:

Ошибка: Fator.hasMany вызван с чем-то, что не является подклассом Sequelize.Model

Любое предложение для устранения ошибки?

модель Fator

'use strict';
const Sub_Fator = require('./sub_fator');

module.exports = (sequelize, DataTypes) => {
  const Fator = sequelize.define('Fator', {
    descricao: DataTypes.STRING
  }, {});
  Fator.associate = function(models) {
      Fator.hasMany(Sub_Fator, {
      foreignKey: 'fatorId',
      as: 'fatores'
    });
  };
  return Fator;
};

модель Sub_fator

'use strict';
const Fator = require('./fator');

module.exports = (sequelize, DataTypes) => {
  const Sub_Fator = sequelize.define('Sub_Fator', {
    fatorId: DataTypes.INTEGER,
    descricao: DataTypes.STRING
  }, {});
  Sub_Fator.associate = function(models) {
    Sub_Fator.belongsTo(Fator, {
      foreignKey: 'fatorId',
      as: 'fatores'
    });
  };
  return Sub_Fator;
};

1 Ответ

0 голосов
/ 08 марта 2020
//Removed this import because is not an object of Model it's a definition
module.exports = (sequelize, DataTypes) => {
  const Fator = sequelize.define('Fator', {
    descricao: DataTypes.STRING
  }, {});
  Fator.associate = function(models) {
      Fator.hasMany(models.Sub_Fator, {//Change to this instead of Sub_Fator
        foreignKey: 'fatorId',
        as: 'fatores'
    });
  };
  return Fator;
};

Причина в том, что вы определяете модель здесь, но затем в своих моделях / индексе. js или что-то в этом роде, вы должны импортировать ее для создания объектной модели, это всего лишь определение модели, и это не подкласс Sequelize.Model.

PS: ваш индекс должен выглядеть примерно так, если вы создали сиквелиз в своем проекте:

'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/server-config.json')[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;
...