javascript-通过Node.js进行的MySQL查询具有未知数量的空参数
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了javascript-通过Node.js进行的MySQL查询具有未知数量的空参数,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1342字,纯文字阅读大概需要2分钟。
内容图文
我正在将this MySQL插件用于Node.js.这是一个非常简单的查询:
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);
});
为每种可能的组合编写一个单独的查询显然是一种粗略的方法,并且如果有多个查询参数,则实际上不是很实用.是否有更优雅(即简明)的方法来解释未知数量的空参数?
更新
这就是对我有用的东西:
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中)即可.
预计到达时间:如果您使用命名参数格式(:param而不是?),这也将节省一些重复.
内容总结
以上是互联网集市为您收集整理的javascript-通过Node.js进行的MySQL查询具有未知数量的空参数全部内容,希望文章能够帮你解决javascript-通过Node.js进行的MySQL查询具有未知数量的空参数所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。