[英]Sequelize has and belongs to many
有没有一种方法可以与贯通表进行多态自关联(例如Collection具有且属于许多Collection)?
尝试使http://docs.sequelizejs.com/manual/tutorial/associations.html#nm适应这种情况:
// Inside collection.js associate
Collection.belongsToMany(Collection, {
through: {
model: models.CollectionItem,
unique: false,
scope: {
collectible: 'collection'
}
},
foreignKey: 'collectibleUid',
constraints: false
});
在哪里collectionItem.js
看起来像
const CollectionItem = sequelize.define("CollectionItem", {
uid: {
type: DataTypes.BIGINT,
primaryKey: true
},
collectionUid: {
type: DataTypes.BIGINT,
allowNull: false,
unique: 'collection_item_collectible'
},
order: {
type: DataTypes.INTEGER,
allowNull: false,
defaultValue: 0
},
collectibleUid: {
type: DataTypes.BIGINT,
allowNull: false,
references: null, // Because the column is polymorphic, we cannot say that it REFERENCES a specific table
unique: 'collection_item_collectible'
},
collectible: {
type: DataTypes.STRING,
allowNull: false,
unique: 'collection_item_collectible'
}
}, {
classMethods: {
}
});
似乎Sequelize希望我通过另一个连接/通过表来命名不同的名称,但这实际上是在创建新表而不是获得真正的hasAndBelongsToMany
类型关系。
错误:必须为多对多自关联定义“ as”
尝试明确并添加:
as: "CollectionItem"
as
不创建新的联接表,它只是为关系指定了名称
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.