javascript - SequelizeEagerLoading错误: parent model is not associated to child

标签 javascript node.js orm sequelize.js

这是父模型/表:

const { Sequelize, DataTypes } = require('sequelize');
const VerifyToken = require('./verifyToken');

module.exports = (sequelize, DataTypes) => {
const User = sequelize.define('User', {
    password: DataTypes.STRING,
    email: DataTypes.STRING,

}, {
    tableName: 'users',
    timestamps: false,
    //syncOnAssociation: true
    hierarchy: true,
    underscored: true

});

User.associate = function (models) {
    const {VerifyToken} = models;

    User.hasOne(VerifyToken, {
        as: 'verify_tokens',
        foreign_key: 'user_id'
    });
};

return User;
};

这是子模型:

const User = require('./user');

module.exports = (sequelize, DataTypes) => {
const VerifyToken = sequelize.define('VerifyToken', {

    user_id: DataTypes.INTEGER,
    token: DataTypes.STRING,

}, {
    tableName: 'verify_tokens',
    hierarchy: true,
    underscored: true
});


VerifyToken.associations = function (models) {
    const {User} = models;

    VerifyToken.belongsTo(User);
};

return VerifyToken;
};

models/index.js 文件:

const fs = require('fs');
const path = require('path');
const Sequelize = require('sequelize');
const basename = path.basename(__filename);
const env = process.env.NODE_ENV || 'development';
const config = require(__dirname + '/../config/config.json')[env];
const db = {};

let sequelize;
if (config.use_env_variable) {
  sequelize = new Sequelize(process.env[config.use_env_variable], config);
} else {
  sequelize = new Sequelize(config.database, config.username, config.password, config);
}

fs
  .readdirSync(__dirname)
  .filter(file => {
    return (file.indexOf('.') !== 0) && (file !== basename) && (file.slice(-3) === '.js');
  })
  .forEach(file => {
    const model = sequelize['import'](path.join(__dirname, file));
    db[model.name] = model;
  });

Object.keys(db).forEach(modelName => {
  if (db[modelName].associate) {
    db[modelName].associate(db);
  }
});

db.sequelize = sequelize;
db.Sequelize = Sequelize;

module.exports = db;

,但是当我进行这样的查询时:

const verifyToken = await models.VerifyToken.findOne({
    where: {
        token
    },
    include:{
        model: models.User
    }
});

我得到这个:

SequelizeEagerLoadingError: User is not associated to VerifyToken!

最佳答案

  1. 请将 VerifyToken.associations 更正为 VerifyToken.associate
  2. 删除 const verifyToken = require('./verifyToken'); 的冗余导入来自用户模型定义。

关于javascript - SequelizeEagerLoading错误: parent model is not associated to child,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61171331/

相关文章:

javascript - 如何通过 webpack 导入 bootstrap?

javascript - 通过 SystemJS 用于 NodeJS 的 TypeScript

node.js - 锁定对象?

Node.js:是否有部署模块可以合并 javascript 文件并缩小它们?

database - 使用 Eloquent ORM 时是否需要在数据库级别维护外键?

nhibernate - 流畅的NHibernate分层数据

go - beego 模型错误

javascript - iframe 和 angularjs 的浏览器历史记录

javascript - 如何应用嵌套选择标签上的更改事件

javascript - JavaScript-使用通配符(*)进行过滤