Nodejs Sequelize отношения не работают

0

Я пытаюсь создать систему, в которой пользователь может быть заинтересован в продуктах. Есть много продуктов, и несколько пользователей могут быть заинтересованы в том же продукте. Я выполнил учебник (https://github.com/ianmunrobot/1702-express-review) и изменил его в моих целях, чтобы создать сценарий seed.js, который создает следующие таблицы в db: интересы, пользователи, продукты, использующие database.js как config. В любом случае, когда я пытаюсь использовать тот же файл database.js с остальной частью моего проекта, я получаю сообщение об ошибке.

user.js

// The User model.
const Sequelize = require('sequelize');
const bcrypt = require('bcrypt');

const config = require('../config');
const db = require('../database');
const Product = require('./Product');

// 1: The model schema.
const modelDefinition = {
  username: {
    type: Sequelize.STRING,
    unique: true,
    allowNull: false
  },
  email: {
    type: Sequelize.STRING,
    unique: true,
    allowNull: false
  },
  password: {
    type: Sequelize.STRING,
    allowNull: false,
  },
  role: {
    type: Sequelize.STRING,
    allowNull: true,
  },
};

// 2: The model options.
const modelOptions = {
  instanceMethods: {
    comparePasswords: comparePasswords,
  },
  hooks: {
    beforeValidate: hashPassword
  },
};

// 3: Define the User model.
const UserModel = db.define('User', modelDefinition, modelOptions);

// Compares two passwords.
function comparePasswords(password, callback) {
  bcrypt.compare(password, this.password, function (error, isMatch) {
    if (error) {
      return callback(error);
    }

    return callback(null, isMatch);
  });
}

// Hashes the password for a user object.
function hashPassword(user) {
  if (user.changed('password')) {
    return bcrypt.hash(user.password, 10).then(function (password) {
      user.password = password;
    });
  }
}

module.exports = UserModel;

Products.js

const Sequelize = require('sequelize');
const db = require('../database');

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

const ProductModel = db.define('Product', {
  name: {
    type: Sequelize.STRING,
    allowNull: false,
  },
  price: {
    type: Sequelize.INTEGER,
  },
});

module.exports = ProductModel;

database.js:

const Sequelize = require('sequelize');
const config = require('./config');

const db = new Sequelize(
  config.db.name,
  config.db.user,
  config.db.password,
  config.db.details,
);

module.exports = db;

const User = require('./models/User.js');
const Product = require('./models/Product.js');

Product.belongsToMany(User, { as: 'users', through: 'Interests' });

app.js:

const express = require('express');
const path = require('path');
const logger = require('morgan');
const cookieParser = require('cookie-parser');
const bodyParser = require('body-parser');
const promisify = require('es6-promisify');
const morgan = require('morgan');
const sequelize = require('sequelize');
const passport = require('passport');
const jwt = require('jsonwebtoken');
const hookJWTStrategy = require('./passportStrategy');

const routes = require('./routes/index');

const app = express();

app.use((req, res, next) => {
  res.header('Access-Control-Allow-Origin', '*');
  res.header('Access-Control-Allow-Credentials', 'true');
  res.header('Access-Control-Allow-Headers', 'Origin, Content-Type,         Authorization, x-id, Content-Length, X-Requested-with');
  res.header('Access-Control-Allow-Methods', 'GET, POST, PUT, DELETE,         OPTIONS');
  next();
});

// view engine setup
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'jade');

app.use(logger('dev'));

app.use(passport.initialize());

// Hook the passport JWT strategy.
hookJWTStrategy(passport);

app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: false }));

app.use(cookieParser());

app.use(express.static(path.join(__dirname, 'public')));

app.use('/', routes);

// catch 404 and forward to error handler
app.use((req, res, next) => {
  const err = new Error('Not Found');
  err.status = 404;
  next(err);
});

// error handler
app.use((err, req, res, next) => {
  // set locals, only providing error in development
  res.locals.message = err.message;
  res.locals.error = req.app.get('env') === 'development' ? err : {};

  // render the error page
  res.status(err.status || 500);
  res.render('error');
});

module.exports = app;

Ожидаемые результаты: пользователь может быть заинтересован в продуктах. Интересы должны быть в таблице интересов, и пользователь должен быть заинтересован во многих продуктах.

Ошибка:

  Error: Product.belongsToMany called with something that not an instance of Sequelize.Model
at Model.Mixin.belongsToMany (/home/mikko/git/s/node_modules/sequelize/lib/associations/mixin.js:252:11)
at Object.<anonymous> (/home/mikko/git/s/database.js:17:9)
Теги:
sequelize.js

1 ответ

0

Я не могу добавить комментарий из-за репутации менее 50. Я предполагаю, что модель пользователя не готова в то время, когда вы пытаетесь ее использовать. Можете ли вы разместить свой app.js или эквивалент? Я подозреваю, что может быть несоответствие между "требованием" и вашими именами.

Я использовал приведенные выше примеры и следующую строку в app.js для запроса database.js:

    var db = require('./database');

Это отлично работает для меня.

Однако, если я изменю его (Uppercase 'D'):

    var db = require('./Database');

Я могу воспроизвести ошибку, которую вы испытываете.

Вам нужно будет вызвать db.sync(), чтобы синхронизировать определенные модели с БД.

      db.sync({force: false})
        .then(message => {
            console.log('db synced');
        })
        .catch(function(err) {
            throw err;
        });

Надеюсь это поможет.

  • 0
    Я добавил app.js. Разве этого недостаточно, чтобы требовать базу данных в файлах модели?
  • 0
    Вам нужно вызвать db.sync () для синхронизации ваших определенных моделей с БД.

Ещё вопросы

Сообщество Overcoder
Наверх
Меню