mysql - 对 MySQL 数据库进行动态 SQL 查询

标签 mysql sql go

我以前从未将 golang 与 mysql 一起使用,所以我是第一次阅读这些内容。我想做这样的事情:

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 循环,我可以动态生成查询并根据需要动态绑定(bind)任意数量的变量。

golang 和 mysql 有这样的选项吗?还是有其他方法可以不为查询键入每个变量组合?

最佳答案

如果您有一个包含如下字段名称和值的 map :

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 注入(inject)的影响,因为占位符用于应用程序直接控制之外的部分查询。

如果已知映射键是允许的字段名称,则使用:

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 - 对 MySQL 数据库进行动态 SQL 查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46859705/

相关文章:

mysql - SQL 最长停留时间

mysql - 删除VB.NET中的SQL语句

sql - 如何使用自连接和分组依据编写查询?

go - 使用 gRPC : how to get the size of the client-side buffer? 的无缓冲双向数据流

sockets - 如何在 Go 中停止监听服务器

mysql - 构建一个按月分割支出的查询。 (将一行变成多行)

mysql - sql mysql 最大()

mysql - 无法更新在 AFTER INSERT 中执行触发器的表

python - 如何编写依赖于子关系列的混合属性?

go - 将指针传递给接口(interface)时函数抛出错误?