我有这个用node.js mysql编写的mysql查询,并且可以在HTTP GET中执行。 https://github.com/felixge/node-mysql
var api_get_func = function (app, url_path) {
function respond(req, res, next) {
var id= req.query.id;
var limit = req.query.limit;
var query_str =
"SELECT table.sw_type, " +
"FROM users " +
"WHERE (id = ?) " +
"LIMIT ?"; //limit
var var_arr = [id, limit];
var query = connection.query(query_str, var_arr, function (err, rows, fields) {}
//SQL query ...
return next();
}
app.get(url_path, respond);
}
HTTP GET网址为http://127.0.0.1/read_sw?id=51&limit=1
报告的错误是查询未正确形成。实际查询看起来像这样;
SELECT table.sw_type,
FROM users
WHERE (id = 51)
LIMIT '1'
我认为问题是LIMIT '1'
。我认为解决方案是使查询看起来像这样;
SELECT table.sw_type,
FROM users
WHERE (id = 51)
LIMIT 1
如何修改node.js代码?
答案 0 :(得分:1)
这不是关于mysql ...
req.query中的任何内容都是一个字符串:
怎么样
var var_arr = [id, parseInt(limit)];
答案 1 :(得分:1)
您也可以使用
var limit = Number(req.query.limit);