gpt4 book ai didi

mysql - Sequelize 4 - eagger 加载时属于多对多插入问题

转载 作者:行者123 更新时间:2023-11-29 18:32:00 25 4
gpt4 key购买 nike

大家好,我有这两个模型:

const media = sequelize.define('media', {
id: { type: Sequelize.UUID, primaryKey: true, defaultValue: Sequelize.UUIDV4 },
name: { type: Sequelize.STRING, allowNull: false, unique:'compositeIndex' },}, { freezeTableName: true });

const mediaGenre = sequelize.define('mediaGenre', {
id: { type: Sequelize.UUID, primaryKey: true, defaultValue: Sequelize.UUIDV4 }}, { freezeTableName: true, name: { plural: 'mediaGenre' } });

这两个关系:

media.hasMany(mediaGenre, as: 'mGenre');
mediaGenre.belongsTo(media);

media.belongsToMany(genre, { through: mediaGenre });
genre.belongsToMany(media, { through: mediaGenre });

当我想创建媒体时,我会这样做:

MediaModels.media.create(
{name: 'Hulk',
mediaGenre: [
{ genreId: '021baab5-7fc6-4b06-aca5-e4b1ed1f3ce4' },
{ genreId: '03f069a4-dc52-4ab5-82d3-6bcd67d2d29e' }]},
{
include: [
{model: MediaModels.mediaGenre, as: 'mGenre'}
]
}
);

这些一直与sequ​​elize 3一起使用,最近我更新到sequelize 4.4.2,它没有抛出错误,但表mediaGenre尚未填充。

有什么想法可能是错误吗?

最佳答案

您在引用关联后是否尝试过同步?我遇到了这个问题,当我调用同步时(强制为 false,如果您不想删除架构并重新创建,这一点很重要),连接表被创建。

如果您使用sequelize-cli,还请注意,在此版本中,不再支持classMethods。相反,您应该直接向您的模型添加一个名为 Associate 的方法,该方法将在您的 models/index.js 中调用。

关于mysql - Sequelize 4 - eagger 加载时属于多对多插入问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45601174/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com