这是我第一次在node(Express)js中编写,我正在尝试连接我的数据库(Mysql)。这就是我找到的app.js
文件的代码。
app.js
var express = require('express'),
mysql = require('mysql');
// Application initialization
var bodyParser = require('body-parser');
var connection = mysql.createConnection({
host : 'localhost',
user : 'root',
password : ''
});
var app = module.exports = express.createServer();
// Database setup
connection.query('CREATE DATABASE IF NOT EXISTS test', function (err) {
if (err) throw err;
connection.query('USE test', function (err) {
if (err) throw err;
connection.query('CREATE TABLE IF NOT EXISTS users('
+ 'id INT NOT NULL AUTO_INCREMENT,'
+ 'PRIMARY KEY(id),'
+ 'name VARCHAR(30)'
+ ')', function (err) {
if (err) throw err;
});
});
});
// Configuration
app.use(express.bodyParser());
// Main route sends our HTML file
app.get('/', function(req, res) {
res.sendfile(__dirname + '/index.html');
});
// Update MySQL database
app.post('/users', function (req, res) {
connection.query('INSERT INTO users SET ?', req.body,
function (err, result) {
if (err) throw err;
res.send('User added to database with ID: ' + result.insertId);
}
);
});
// Begin listening
app.listen(3000);
console.log("Express server listening on port %d in %s mode", app.address().port, app.settings.env);
但是当我在CMD> node app.js
中运行这个app.js文件时我收到此错误。
c:\express\testproject>node app.js
c:\express\testproject\app.js:13
var app = module.exports = express.createServer();
^
TypeError: Object function createApplication() {
var app = function(req, res, next) {
app.handle(req, res, next);
};
mixin(app, proto);
mixin(app, EventEmitter.prototype);
app.request = { __proto__: req, app: app };
app.response = { __proto__: res, app: app };
app.init();
return app;
} has no method 'createServer'
at Object.<anonymous> (c:\express\testproject\app
at Module._compile (module.js:456:26)
at Object.Module._extensions..js (module.js:474:1
at Module.load (module.js:356:32)
at Function.Module._load (module.js:312:12)
at Function.Module.runMain (module.js:497:10)
at startup (node.js:119:16)
at node.js:902:3
我无法弄清楚究竟是什么问题。
答案 0 :(得分:3)
在为Express 3编写代码时,您似乎正在使用Express 4.
createServer
已被删除。
只需使用express()
即可创建新应用。
答案 1 :(得分:0)
has no method 'createServer'.
这解释了你的原因。所以你的代码行
var app = module.exports = express.createServer();
不是有效的通话。因此,如上所述,您的工作目录中有Express 4,并且您已调用属于Express 3的方法。
var app = express();
答案 2 :(得分:0)
首先安装mysql模块
config.json
然后创建一个文件db.js或您喜欢的名称。
npm install mysql –save
答案 3 :(得分:0)
您可以使用sequlize
const sequelize = new Sequelize(env.database, env.username, env.password, {
host: env.host,
dialect: env.dialect,
operatorsAliases: 1,
pool: {
max: env.max,
min: env.pool.min,
acquire: env.pool.acquire,
idle: env.pool.idle
}
});