Javascript TypeError:使用Sequelize在NodeJs中定义模型时,对象不是函数
这是我的managedb.jsJavascript TypeError:使用Sequelize在NodeJs中定义模型时,对象不是函数,javascript,node.js,sequelize.js,Javascript,Node.js,Sequelize.js,这是我的managedb.js var Sequelize = require('sequelize-postgres').sequelize; var postgres = require('sequelize-postgres').postgres; var pg = require('pg'); var db = new Sequelize('tesf3', 'postgres', 'postgres', { dialect: 'postgres', port: '5432'
var Sequelize = require('sequelize-postgres').sequelize;
var postgres = require('sequelize-postgres').postgres;
var pg = require('pg');
var db = new Sequelize('tesf3', 'postgres', 'postgres', {
dialect: 'postgres',
port: '5432',
omitNull: true
});
module.exports.db = db;
var Link = db.import(__dirname + '/lib/link/models').Link;
var LinkUser = db.import(__dirname + '/lib/link/models').LinkUser;
module.exports.Link = Link;
module.exports.LinkUser = LinkUser;
这是库中的my models.js:
var sequelize = require('../../managedb').db;
var DataTypes = require('sequelize-postgres').sequelize;
var Link = sequelize.define('Link', {
url: {
type: DataTypes.STRING,
validate:{
isUrl: true,
notEmpty: true,
notNull: true
}
},
context: {
type: DataTypes.STRING,
defaultValue: " "
},
previewImage: {
type: DataTypes.STRING
},
source:{
type: DataTypes.STRING
},
shortUrl:{
type: DataTypes.STRING
},
viewed:{
type: DataTypes.STRING
},
image:{
type: DataTypes.STRING
},
id: {
type: DataTypes.INTEGER,
primaryKey: true,
autoIncrement: true
}
},
{
instanceMethods: {
countTasks: function() {
// how to implement this method ?
}
}
});
var LinkUser = sequelize.define('LinkUser', {
linkId: {
type: DataTypes.INTEGER
},
userId: {
type: DataTypes.INTEGER
},
id: {
type: DataTypes.INTEGER,
primaryKey: true,
autoIncrement: true
}
},
{
instanceMethods: {
countTasks: function() {
// how to implement this method ?
}
}
});
module.exports.Link = Link;
module.exports.LinkUser = LinkUser;
我哪里做错了?我不能在一个js文件中定义多个模型吗 。我有一个单独的文件中的每个模型。例如,link.js可以是这样的:
module.exports = function(sequelize, DataTypes) {
return sequelize.define('Link', {
url: {
type: DataTypes.STRING,
validate:{
isUrl: true,
notEmpty: true,
notNull: true
}
},
context: {
type: DataTypes.STRING,
defaultValue: " "
},
...
});
}
然后在managedb.js文件中,可以循环浏览以下文件:
// load models
var models = [
'Link',
'LinkUser'
];
models.forEach(function(model) {
module.exports[model] = sequelize.import(__dirname + '/' + model);
});
如果你发布跟踪,这将很有帮助