NodeJS和MySQL第一次查询后出现Getting 500错误
NodeJS and MySQL Getting 500 error after first query
我已经声明了mysql
,并且我在app.js
中的连接是这样的:
var mysql = require('mysql');
var connection = mysql.createConnection({
host: '192.168.1.75',
user: 'dev',
password: 'devaccount',
database: 'PugIt'
});
app.set('connection', connection);
在我的注册User.js
中,我有:
router.route('/register/steam/finish')
.get(function(req, res) {
res.render('user/register_steam');
})
.post(function(req, res) {
var connection = req.app.get('connection');
connection.connect();
// Look For Users
connection.query("SELECT * FROM Users", function(err, rows, fields) {
console.log('We Found Something!');
});
connection.end();
});
当页面第一次加载并且我点击register时,它工作得很好,但如果我第二次点击按钮,我的服务器上就会出现500
错误。
但是,如果我在每个route
文件中手动声明var connection
,则不会发生这种情况。
为什么我不能将req.app.get
与MySQL一起使用,我在使用MongoDB
时使用了这种方法,这种方法非常有效。如果需要,我可以在app.js中更改一个主配置,以更改所有路由文件。不确定为什么在第二个POST
上出现500
错误
我认为每个POST
请求上的connection.connect()
和connection.end()
都会导致问题。放下这两行字,你就可以走了。这样,连接只建立一次,所有请求都可以重用同一个连接,而无需不断尝试将其拆除并重新启动。
如果您发现自己需要更大的数据库查询并发性,也可以创建一个mysql连接池。
相关文章:
- Node.js v6.2.0类扩展不是函数错误
- Jquery菜单操作不稳定,定位不正确,存在一般错误
- document.open/document.write没有正确地清除chrome中的文档——这是chrome的错误吗
- 试图在引导模式内动态生成图表,得到offsetWidth错误
- 为什么会出现错误;未捕获的类型错误:undefined不是函数;
- 我如何修复包含在captcha的addthis中的错误
- 同样,同样的错误'ahorcado.js:26未捕获类型错误:无法读取属性'beginPath'
- 节点是否需要模块传递带有方括号的arg?这是个错误吗
- Webpack/Rect:遵循egghead.io教程,但出现错误:您可能需要一个合适的加载程序来处理此文件类型
- CKFinder 3为所选文件返回错误的URL
- 同位素库错误:未捕获错误无布局模式包装生产线8
- 铬:“;未捕获的语法错误:意外的标记:"
- 如何通过自己获得Chrome扩展的用户反馈/错误报告
- 相位器状态未捕获参考错误
- /undefined在我的404错误日志中多次出现
- Javascript未捕获语法错误意外的标识符错误
- NodeJS和MySQL第一次查询后出现Getting 500错误
- Getting 500:从javascript发送http请求时,来自Web服务器的响应出现内部服务器错误
- Nginx没有加载Meteor包:Getting 404错误
- jQuery Getting: Uncaught Error:语法错误,无法识别的表达式:#/app/home