繁体   English   中英

MySQL通过Node.js查询具有未知数量的空参数

[英]MySQL query via Node.js with an unknown number of null parameters

我正在为Node.js使用这个 MySQL插件。 这是一个非常简单的查询:

db.query("SELECT * FROM user WHERE first = ? AND last = ?", [req.query.first, req.query.last], function(error, results) {
    console.log(results);
});

现在问题是:如果只定义了一些查询参数, 但不是全部都是如此 这是一个非常常见的用例,所以我猜有一种优雅的方法可以解释这个问题,但这是我能想到的全部内容:

var query;
if (first && !last) {
    query = "SELECT * FROM user WHERE first = ?";
} else if (!first && last) {
    query = "SELECT * FROM user WHERE last = ?";
} else if (first && last) {
    query = "SELECT * FROM user WHERE first = ? AND last = ?";
}
db.query(query, [req.query.first, req.query.last], function(error, results) {
    console.log(results);
});

为每个可能的组合编写单独的查询显然是一种粗略的方法,如果不仅仅是一些查询参数,那么实际上并不是很实用。 是否有更优雅(即简洁)的方法来解释未知数量的空参数?

UPDATE

这最终为我工作:

db.query("SELECT * FROM user WHERE (:first IS NULL || first = :first) AND (:last IS NULL || last = :last)", {first: req.query.first, last: req.query.last}, function(error, results) {
    console.log(error);
});

这可能有点麻烦,但您可以使用此查询:

query = "SELECT * FROM user WHERE (? IS NULL || first = ?) AND (? IS NULL || last = ?)";

只需确保至少有一个参数不为null(在查询中或在js中)。

ETA:如果你使用命名参数格式(:param而不是?),这也会为你节省一些重复。

动态构建查询。 就像是:

var params = ["first", "last"];
var conds = [];
var args = [];
var i;
for (i = 0 ; i < params.length ; i++)
{
    var p = params[i];
    if (req.query[p] !== undefined)
    {
        conds.push(p+'=?');
        args.push(req.query[p]);
    }
}
var query = 'SELECT * FROM user WHERE '+conds.join(' AND ');
db.query(query,args, etc.);

你需要处理没有条件的情况(你必须选择是否全部匹配)。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM