node js Express mysql连接

时间:2014-05-13 07:23:28

标签: javascript mysql node.js express

这是我第一次在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

我无法弄清楚究竟是什么问题。

4 个答案:

答案 0 :(得分:3)

在为Express 3编写代码时,您似乎正在使用Express 4.

createServer已被删除。

只需使用express()即可创建新应用。

参考:Migrating from Express 3 to Express 4

答案 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
}
});