【发布时间】:2015-12-13 11:52:30
【问题描述】:
我正在尝试将 sequelizejs 与 express 一起使用。模型被组织到多个目录中。
Users(directory)
users.js
profile.js
...
Articles
article.js
comments.js
...
我已修改 sequelize-express 示例以循环遍历子目录并使用 Promise 导入模型。
sequelize_init.js
'use strict';
var fs = require('fs'),
path = require('path'),
_ = require('lodash'),
config = require('./auth-config'),
Sequelize = require('sequelize'),
glob = require('glob'),
Q = require('q'),
db = {};
var sequelize;
function getGlobbedModels() {
var deferred = Q.defer();
glob('./config/sequelize/models/**/*.js', function(err, files) {
if(err)
deferred.reject('Glob Error' + err);
else
deferred.resolve(files);
});
return deferred.promise;
}
function importModels(models){
var deferred = Q.defer();
for (var i = models.length - 1; i >= 0; i--) {
if(!i) {
deferred.resolve('Successfully Required');
}
var model = sequelize.import(path.resolve(models[i]));
db[model.name] = model;
}
return deferred.promise;
}
function associateModels(resp) {
var deferred = Q.defer();
var models = Object.keys(db);
for (var i = models.length - 1; i >= 0; i--) {
if(!i) {
deferred.resolve();
}
if(db[models[i]].options.hasOwnProperty('associate')) {
db[models[i]].options.associate(db);
}
}
return deferred.promise;
}
function synchronize() {
// Synchronizing any model changes with database.
sequelize
.sync({
force: process.env.FORCE_DB_SYNC
})
.then(function () {
console.info('Database synchronized');
}).catch(function (err) {
console.error('An error occurred: ', err);
});
}
if(process.env.NODE_ENV === 'PRODUCTION') {
//Use production DB
}else {
//Use local DB
sequelize = new Sequelize(...);
}
getGlobbedModels()
.then(importModels)
.fail(function(err){
console.error('importModels err ' + err);
})
.then(associateModels)
.fail(function(err){
console.error('associateModels err' + err);
})
.then(synchronize)
.fail(function(err){
console.error('synchronize err' + err);
});
// assign the sequelize variables to the db object and returning the db.
module.exports = _.extend({
sequelize: sequelize,
Sequelize: Sequelize
}, db);
在我的 app.js 文件中,我需要以下代码,但模型在导出到 require 调用时未定义。我已经验证了上面的 db 对象,并且模型成功地被要求,但没有被导出到 require 调用中。
app.js
var models = require('./sequelize_init.js');
models.User.findAll().then(); // Throws undefined error
【问题讨论】:
标签: node.js express orm sequelize.js