我有一个项目,我正在尝试使用sequelize。它可以很好地创建数据库和表,但它永远不会找到关联类方法,因此它永远不会调用关联方法。
此代码可以很好地创建表(使用import方法),但Object.keys(db)遍历每个模型,但它永远不会找到关联方法。
fs.readdirSync('./models')
.filter(function (file) {
return (file.indexOf('.') !== 0) && (file !== 'index.js') && (file.indexOf('.js') > 0) && (file.indexOf('relations.js') !== 0 );
})
.forEach(function (file) {
var model = sequelize.import('../models/' + file);
db[model.name] = model;
});
Object.keys(db).forEach(function (modelName) {
if (db[modelName].associate) {
db[modelName].associate(db);
console.log('true');
}
else {
console.log('false');
}
}
);
类代码示例:
module.exports = function(sequelize,DataTypes){
let userModel = sequelize.define('user', {
id: {
type: DataTypes.INTEGER,
primaryKey: true,
autoIncrement: true
},
email: {
type: DataTypes.STRING,
validate: {
isEmail: true
},
allowNull: false
}
}, {
classMethods: {
associate: function (models) {
let createdByoptions = {
foreignKey: 'createdByUserID'
};
let emailOptions = {
foreignKey: 'emailAddressID'
};
userModel.hasOne(models.user, createdByoptions);
userModel.hasOne(models.email, emailOptions)
//userModel.hasMany(models.tenant, {foreignKey: 'id'});
},
addUser: function (identityID) {
userModel.create({identityUserID: identityID});
}
}
});
return userModel;
};
答案 0 :(得分:3)
Sequelize改变了关联和实例方法的定义方式,发布版本> 4。
因此,协会早先定义为(对于版本<4)
const Model = sequelize.define('Model', {
...
}, {
classMethods: {
associate: function (model) {...}
},
instanceMethods: {
someMethod: function () { ...}
}
});
现在应该定义为
const Model = sequelize.define('Model', {
...
});
// Class Method
Model.belongsTo(SomeOtherModel);