【发布时间】:2019-02-19 22:45:04
【问题描述】:
我正在使用 sequelize 和 mysql 方言在 Nodejs 中构建一个应用程序。我可以很好地生成迁移,但不能运行它们来填充数据库中的表。这就是我运行 db:migrate: 时得到的结果:
Sequelize CLI [Node: 8.9.4, CLI: 4.1.1, ORM: 4.38.1]
Loaded configuration file "config\config.json".
Using environment "development".
sequelize deprecated String based operators are now deprecated. Please use Symbo
l based operators for better security, read more at http://docs.sequelizejs.com/
manual/tutorial/querying.html#operators ..\..\Users\Admin\AppData\Roaming\npm\no
de_modules\sequelize\lib\sequelize.js:242:13
ERROR: connect ETIMEDOUT
我尝试在数据库连接中设置 operatorsAliases: false, 没有运气。
这是我的数据库连接:
'use strict';
var fs = require('fs');
var path = require('path');
var Sequelize = require('sequelize');
var basename = path.basename(__filename);
var env = process.env.NODE_ENV || 'development';
var config = require(__dirname + '/../config/config.json')[env];
var db = {};
const Op = Sequelize.Op;
if (config.use_env_variable) {
var sequelize = new Sequelize(process.env[config.use_env_variable], config,{ operatorsAliases: false });
} else {
var sequelize = new Sequelize(config.database,
config.username,
config.password,
{
operatorsAliases: false,
host: config.host,
dialect: config.dialect,
}
);
//check if connection is established
sequelize
.authenticate()
.then(() => {
console.log('Database Connection has been established successfully.');
})
.catch(err => {
console.error('Unable to connect to the database:', err);
});
}
fs
.readdirSync(__dirname)
.filter(file => {
return (file.indexOf('.') !== 0) && (file !== basename) && (file.slice(-3) === '.js');
})
.forEach(file => {
var model = sequelize['import'](path.join(__dirname, file));
db[model.name] = model;
});
Object.keys(db).forEach(modelName => {
if (db[modelName].associate) {
db[modelName].associate(db);
}
});
db.sequelize = sequelize;
module.exports = db;
该应用程序正在正常连接到数据库。最初我遇到了这个问题,然后执行的迁移成功了。使用 ORM 从现有表中添加检索记录工作得很好。但我无法运行新的迁移来创建新表。
任何解决此问题的建议将不胜感激。我可以说我已经尝试了在线可用的解决方案,但没有处理我的情况。谢谢。
【问题讨论】:
-
Sequelize CLI 警告不应阻止您的迁移执行,这是已知问题 AFAIK。似乎 Sequelize 无法连接到数据库。您是否正确指定了数据库连接?
标签: mysql node.js express sequelize.js