sequelize SequelizeEagerLoadingError: version is not associated to game!

本文分享了在使用Sequelize进行关联查询时遇到的问题及解决办法,详细介绍了如何通过调整include配置从一对多关系中正确加载数据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

sequelize踩的坑记录一下:

问题:sequelize SequelizeEagerLoadingError: version is not associated to game!明明已经指定了一对多关系,但是关联查询的时候还是提示没有建立联系。

解决:

include的写法有问题,将model改为association,model写法是已有联系的查询,association时没有联系时建立一个联系后再查询。详细参考:https://itbilu.com/nodejs/npm/EkWJSmmFf.html

const res = await GameModel.findAll({

    limit: 5,

    include: [{

      model: VersionModel,

      attributes: ['developPlan', 'publishPlan', 'status']

    }]

  })

改成下面的就对了。

const res = await GameModel.findAll({

    limit: 5,

    include: [{

      association: GameModel.hasMany(VersionModel, {}),

      attributes: ['developPlan', 'publishPlan', 'status']

    }]

  })

反思:学新东西的时候容易把容易陷入一点当中,停留在当前的错误上,殊不知前面的基础可能已经出错了,所以长时间没有解决问题时,可以跳回上一级,将上一级的东西一个一个否定,然后排查错误。就比如:停留在为什么明明model已经建立联系,还是报没有建立联系的错误,长时间没有解决,回到上一级或最初,目的是为了关联查询,应该考虑关联查询的写法是否正确,这个确实有点难,想不到,但是问题确实是这样才能解决,不过是经验。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值