我正在使用带有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;
};
答案 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({})。然后