对MySQL DB进行动态SQL查询

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了对MySQL DB进行动态SQL查询相关的知识,希望对你有一定的参考价值。

我之前从未使用过带有mysql的golang,所以我第一次阅读这些内容。我想做这样的事情:

if userId && gender && age
db.QueryRow("SELECT name FROM users WHERE userId=? AND gender=? AND age=?", userId,gender,age)
else if gender && age
db.QueryRow("SELECT name FROM users WHERE gender=? AND age=?", gender, age)
else if userId && gender
db.QueryRow("SELECT name FROM users WHERE userId=? AND gender=?", userId,gender)
else if userId && age
db.QueryRow("SELECT name FROM users WHERE userId=? AND age=?", userId, age)
else if gender
db.QueryRow("SELECT name FROM users WHERE gender=?", gender)
else if userId
db.QueryRow("SELECT name FROM users WHERE userId=?", userId)
else if age
db.QueryRow("SELECT name FROM users WHERE age=?", age)

这是太多的输入,特别是如果我有更多的变量我想添加到WHERE条件。

如果这是php,我会做这样的事情:

$sql = "SELECT name FROM users ";
$where = array();
foreach(explode(",","userId,gender,age,name,height,weight,ethnicity" as $field)
{
    if(isset($arrayOfValues[$field]))
    {
        $where[count($where)] = $field." = ?".$field
        $db->bind("?".$field,$arrayOfValues[$field]);
    }
}

if(count($where)>0)
$sql = $sql . " WHERE ".implode(" AND ",$where);
$db->query($sql);

通过使用foreach循环,我可以动态生成查询并根据需要动态绑定任意数量的变量。

这是golang和mysql的选项吗?或者是否有替代方法可以不为查询键入每个变量组合?

答案

如果你有一个包含字段名称和值的地图,如下所示:

m := map[string]interface{}{"UserID": 1234, "Age": 18}

然后你可以像这样构建查询:

var values []interface{}
var where []string
for _, k := range []string{"userId","gender","age","name","height","weight","ethnicity"}
if v, ok := m[k]; ok {
    values = append(values, v)
    where = append(where, fmt.Sprintf("%s = ?", k))
}
r, err := db.QueryRow("SELECT name FROM users WHERE " + strings.Join(where, " AND "), values...)

这不容易受SQL注入影响,因为占位符用于应用程序直接控制之外的部分查询。

如果已知地图键是允许的字段名称,则使用以下命令:

var values []interface{}
var where []string
for k, v := range m {
    values = append(values, v)
    where = append(where, fmt.Sprintf("%s = ?", k))
}
r, err := db.QueryRow("SELECT name FROM users WHERE " + strings.Join(where, " AND "), values...)

以上是关于对MySQL DB进行动态SQL查询的主要内容,如果未能解决你的问题,请参考以下文章

mybatis入门基础----动态SQL

部分代码片段

如何使用 LINQ 针对 Azure Cosmos Document DB SQL API 有效地进行动态查询?

Mybatis -- 动态Sql概述动态Sql之<if>(包含<where>)动态Sql之<foreach>sql片段抽取

MySQL 到 Drupal 7 db_select

MySQL学习小结