NodeJS - 连接到本地 Mysql 数据库
NodeJS - Connecting to a local Mysql Database
我正在尝试为我的节点应用程序创建一个 mysql 数据库连接,并 运行 sequelize.authenticate().then(function(errors) { console.log(errors) });
来测试连接是否有效。记录到我的控制台的响应是 Executing (default): SELECT 1+1 AS result undefined
undefined
部分让我认为连接不起作用或者没有找到任何数据库。我似乎无法弄清楚。我想通过 Sequel Pro 创建数据库并通过 Socket 连接到 localhost
,我可以使用相同的凭据连接我的 Node 应用程序。我是否需要在我的应用程序中为数据库创建一个文件而不使用 Sequel Pro 数据库?
控制器文件(创建连接的地方):
var Sequelize = require('sequelize');
var sequelize = new Sequelize('synotate', 'root', '', {
host:'localhost',
port:'3306',
dialect: 'mysql'
});
sequelize.authenticate().then(function(errors) { console.log(errors) });
var db = {}
db.Annotation = sequelize.import(__dirname + "/ann-model");
db.sequelize = sequelize;
db.Sequelize = Sequelize;
module.exports = db;
ann-model.js(定义我的 table):
module.exports = function(sequelize, DataTypes) {
var Ann = sequelize.define('annotations', {
ann_id: {
type: DataTypes.INTEGER,
primaryKey: true
},
ann_date: DataTypes.DATE,
}, {
freezeTableName: true
});
return Ann;
}
试试这个,Executing (default): SELECT 1+1 AS result
表示一切正常
sequelize
.authenticate()
.then(function(err) {
if (!!err) {
console.log('Unable to connect to the database:', err)
} else {
console.log('Connection has been established successfully.')
}
});
但我不知道你从哪里得到的 undefined
我正在尝试为我的节点应用程序创建一个 mysql 数据库连接,并 运行 sequelize.authenticate().then(function(errors) { console.log(errors) });
来测试连接是否有效。记录到我的控制台的响应是 Executing (default): SELECT 1+1 AS result undefined
undefined
部分让我认为连接不起作用或者没有找到任何数据库。我似乎无法弄清楚。我想通过 Sequel Pro 创建数据库并通过 Socket 连接到 localhost
,我可以使用相同的凭据连接我的 Node 应用程序。我是否需要在我的应用程序中为数据库创建一个文件而不使用 Sequel Pro 数据库?
控制器文件(创建连接的地方):
var Sequelize = require('sequelize');
var sequelize = new Sequelize('synotate', 'root', '', {
host:'localhost',
port:'3306',
dialect: 'mysql'
});
sequelize.authenticate().then(function(errors) { console.log(errors) });
var db = {}
db.Annotation = sequelize.import(__dirname + "/ann-model");
db.sequelize = sequelize;
db.Sequelize = Sequelize;
module.exports = db;
ann-model.js(定义我的 table):
module.exports = function(sequelize, DataTypes) {
var Ann = sequelize.define('annotations', {
ann_id: {
type: DataTypes.INTEGER,
primaryKey: true
},
ann_date: DataTypes.DATE,
}, {
freezeTableName: true
});
return Ann;
}
试试这个,Executing (default): SELECT 1+1 AS result
表示一切正常
sequelize
.authenticate()
.then(function(err) {
if (!!err) {
console.log('Unable to connect to the database:', err)
} else {
console.log('Connection has been established successfully.')
}
});
但我不知道你从哪里得到的 undefined