我有两个模型(在不同的文件上:
user.js的
module.exports = (sequelize, DataTypes) => {
let user = sequelize.define('user', {
user_id: DataTypes.INTEGER,
first_name: DataTypes.STRING,
last_name: DataTypes.STRING,
email: DataTypes.STRING,
password: DataTypes.STRING,
phone: DataTypes.STRING,
is_phone_verified: DataTypes.BOOLEAN,
}, {
underscored: true,
classMethods: {
associate(models) {
user.hasOne(models.userBankAccount);
},
},
});
return user;
};
user_bank_account.js
module.exports = (sequelize, DataTypes) => {
const userBankAccount = sequelize.define('user_bank_account', {
user_bank_account_id: DataTypes.INTEGER,
user_id: DataTypes.INTEGER,
item_id: DataTypes.STRING,
access_token: DataTypes.STRING,
checking_account_id: DataTypes.STRING,
}, {
underscored: true,
classMethods: {
associate(models) {
userBankAccount.belongsTo(models.user);
},
},
});
return userBankAccount;
};
当我运行sequelize db:migrate
时,Postgres DB中没有创建外键。
我使用sequelize v4。
有什么想法吗?
答案 0 :(得分:2)
classMethods
属性不适用于Sequelize的v4。
您应该直接调用关联方法。例如:
userBankAccount.associate = function(models) {}
user.associate = function(models) {}