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