当前位置: 代码迷 >> 综合 >> sequelize SequelizeEagerLoadingError: version is not associated to game!
  详细解决方案

sequelize SequelizeEagerLoadingError: version is not associated to game!

热度:10   发布时间:2024-02-19 19:28:53.0

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已经建立联系,还是报没有建立联系的错误,长时间没有解决,回到上一级或最初,目的是为了关联查询,应该考虑关联查询的写法是否正确,这个确实有点难,想不到,但是问题确实是这样才能解决,不过是经验。

  相关解决方案