gpt4 book ai didi

sql - 如何在 SQL 选择查询中展开一个 int 对列表

转载 作者:IT王子 更新时间:2023-10-29 02:15:51 25 4
gpt4 key购买 nike

我有以下参数列表:

params := [(p_1, m_1), ..., (p_n, m_n)]  // p_i, m_i : int

现在我想构建一个遍历列表并匹配参数的查询:(for 之后的部分是我想在PostgreSQL 9.4 中编写的伪代码)

SELECT * FROM X WHERE p = p_i AND m = m_i  for (p_i, m_i) in params

如何在 Go 中编写此查询(使用 jmoiron.github.io/sqlx 或标准 database/sql)?

type Param struct {
P, M int
}
params := []Param{{1,2}, {3,4}}
// ???

最佳答案

如评论中所述,IN 检查应该可以满足您的需求:

遍历参数以生成查询的 IN 部分:

paramStr := make([]string, len(params), len(params))
for i, p := range params {
paramStr[i] = fmt.Sprintf("(%d, %d)", p.P, p.M)
}

然后,加入params并执行:

err := dbm.Select(&rows, "SELECT * FROM X WHERE (p, m) IN (%s)",
strings.Join(paramStr, ","))

在这里,对于选择,我使用了 modl这是 sqlx 之上的实用程序。

关于sql - 如何在 SQL 选择查询中展开一个 int 对列表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31312886/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com