Nodejs - 无法读取未定义的属性'findAll'

时间:2017-02-15 11:23:55

标签: node.js postgresql

我正在使用带有sequelize的nodejs并连接到postgres数据库。

我创建了一个模型,在我的一条路线中,我正在尝试返回数据库中的所有用户。

代码:

routes.js

var models = require('../server/models/index');
router.get('/users', function(req, res, next) {

    models.Users.findAll({}).then(function(user) {

    });
});

/ server / models / index

'use strict';

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

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

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

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

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

module.exports = db;

运行服务器并导航到服务器时,我得到以下信息:

Cannot read property 'findAll' of undefined

我测试了连接,它一切正常。我似乎无法弄清楚这里出了什么问题。对我缺少的任何想法?

编辑:

users.js

'use strict';
module.exports = function(sequelize, DataTypes) {
  var Users = sequelize.define('users', {
    email: DataTypes.STRING
  }, {
    classMethods: {
      associate: function(models) {
        // associations can be defined here
      }
    }
  });
  return Users;
};

3 个答案:

答案 0 :(得分:1)

而不是sequelize.define('users');

尝试var Users = sequelize.define('Users');或var Users = sequelize.define('User');

答案 1 :(得分:0)

使用序列化模型时,需要使用定义的模型类名称。

var models = require('../server/models');
router.get('/users', function(req, res, next) {

    models.Users.findAll({}).then(function(user) {

    });
});

答案 2 :(得分:-2)

模型
var user = sequelize.define(' userModel');

路由器
错误:模型。 userModel .findAll({})。然后