Я пытался создать связь между двумя таблицами и хотел добавить внешний ключ.
Две модели: Пользователь и Компания
User.associate = (models) => {
User.belongsTo(models.Companies, { foreignKey: 'Company' });
};
Я ожидал, что приведенный выше код заключается в том, что в таблицу пользователей добавляется поле «Идентификатор компании», которое ссылается на идентификатор компании в таблице «Компании».
При запуске кода выше я не вижу создания дополнительных столбцов. Я попытался проверить, создана ли ассоциация внешнего ключа в БД, но она также отсутствует.
Однако, если я пытаюсь добавить столбец с тем же именем, сохраняя при этом код ассоциации, я получаю конфликт имен. Кажется, это говорит о том, что ассоциация создается, но я не могу ее увидеть.
Может ли кто-нибудь помочь мне понять, что я делаю неправильно? Спасибо за помощь!
Модели / company.js
module.exports = (sequelize, DataTypes) => {
var Company = sequelize.define('company', {
company: { type: DataTypes.STRING, primaryKey: true },
});
Company.associate = (models) => {
Company.hasMany(models.user, { as: 'users' });
};
Company.sync();
return Company;
};
Модели / user.js
const uuid = require('uuid/v4');
'use strict';
module.exports = (sequelize, DataTypes) => {
var User = sequelize.define('user', {
id: { type: DataTypes.UUID, primaryKey: true },
name: { type: DataTypes.STRING, allowNull: false }
});
User.associate = (models) => {
User.belongsTo(models.company);
};
User.beforeCreate((user, _ ) => {
user.id = uuid();
return user;
});
User.sync();
return User;
};
Модели / index.js
'use strict';
var fs = require('fs');
var path = require('path');
var Sequelize = require('sequelize');
var basename = path.basename(__filename);
var env = process.env.NODE_ENV || 'development';
// var config = require(__dirname + '/../config/config.js')[env];
var db = {};
// if (config.use_env_variable) {
// var sequelize = new Sequelize(process.env[config.use_env_variable], config);
// } else {
// var sequelize = new Sequelize(config.database, config.username, config.password, config);
// }
const sequelize = new Sequelize('postgres://postgres:user@localhost:5432/mydb');
fs
.readdirSync(__dirname)
.filter(file => {
return (file.indexOf('.') !== 0) && (file !== basename) && (file.slice(-3) === '.js');
})
.forEach(file => {
var model = sequelize['import'](path.join(__dirname, file));
db[model.name] = model;
});
Object.keys(db).forEach(modelName => {
if (db[modelName].associate) {
db[modelName].associate(db);
}
});
db.sequelize = sequelize;
db.Sequelize = Sequelize;
module.exports = db;