ExpressでノードにREST APIを作成しようとしています。ブラウザで初めてURLを開くと、うまく動作して正しい出力が得られます。ノードjs mysqlクエリで2回目の実行時にエラーが発生する
がvar express = require('express');
var mysql = require('mysql');
var app = express();
var connection = mysql.createConnection({
host: 'localhost',
user: 'USER_NAME',
password: 'PASSWORD'
});
app.use(express.static(__dirname + '/public'));
var port = 3333;
app.get('/api/users/:user_id', function(req, res){
var lead_id = req.params.user_id;
connection.connect();
connection.query('use DB_NAME;', function (err) {
if(err) throw err;
connection.query('select * from users where user_id = ' + user_id, function (err, rows) {
if(err) throw err;
res.json(rows);
connection.end();
});
});
});
app.listen(port);
console.log("The app is running on port " + port);
は、誰かが私に言うことができる私が間違って何をやっている:これは私が使用しているコードがある
events.js:141 throw er; // Unhandled 'error' event ^
Error: Cannot enqueue Handshake after invoking quit.
:私は二度目のAPIのURLを打ったときしかし、アプリがエラーでクラッシュ?
単一の接続の代わりにプールを使用することを検討してください。接続をしたいときはpool.getConnection()を使い、終了したらconnection.release()を使います。 – Dave