В качестве составного первичного ключа модели можно определить два внешних ключа?Sequelize, внешние ключи как составной первичный ключ
Пользователь может быть членом только одной семьи, семья может иметь много членов и таблица семьи-членов нужны ссылки на пользователя и семьи
const User = sequelize.define(
'User',
{
id: { type: dataTypes.INTEGER.UNSIGNED, autoIncrement: true, primaryKey: true },
name: { type: dataTypes.STRING(30) },
email: { type: dataTypes.STRING(30) }
...
},
{
classMethods: {
associate(models) {
User.hasOne(models.FamilyMember, {
foreignKey: 'user_id'
}
}
}
}
)
const Family = sequelize.define(
'Family',
{
name: { type: dataTypes.STRING(30) }
},
{
classMethods: {
associate(models) {
Family.hasMany(models.FamilyMember, {
foreignKey: 'family_id'
}
}
}
}
)
const FamilyMember = sequelize.define(
'FamilyMember',
{
name: { type: dataTypes.STRING(30) },
/*
family_id and user_id will be here after associations but I wanted them to be a composite primaryKey
*/
}
)
Я не уверен, что вы можете создать составной первичный ключ, но я знаю, что вы можете создать составной уникальный ключ. Я не уверен, что они помогают в вашей ситуации. –