我正在嘗試使用帶有未定義參數(shù)數(shù)量的 IN 運(yùn)算符在我的 Golang 項(xiàng)目中使用 MySQL 查詢。我正在使用該包github.com/go-sql-driver/mysql并嘗試在此 Stackoverflow 答案上構(gòu)建我的解決方案:如何使用 Golang 在 SQL 中執(zhí)行 IN 查找?我讀過(guò)一些類似的帖子,給了我一些關(guān)于前進(jìn)方向的建議,但我被困在查詢的執(zhí)行部分,因?yàn)樗辉试S直接使用切片作為參數(shù)。//converting my form args []string into []intvar args []intfor _, v := range r.Form["type"] { t, _ := strconv.Atoi(v) args = append(args, t)}sql := "SELECT id, name FROM resources WHERE id IN (SELECT resource_id FROM resources_types WHERE type_id IN (?" + strings.Repeat(",?", len(args)-1) + "))"fmt.Println("Query : ", sql)stmt, _ := db.Prepare(sql)rows, err := stmt.Query(args)defer stmt.Close()Golang 在執(zhí)行時(shí)返回一個(gè)錯(cuò)誤:查詢:SELECT id, name FROM resources WHERE id IN (SELECT resource_id FROM resources_types WHERE type_id IN (?,?)) “sql: 語(yǔ)句需要 2 個(gè)輸入;得到 1”當(dāng)我嘗試時(shí)它有效rows, err := stmt.Query(args[0], args[1])但由于我需要未定義數(shù)量的參數(shù),這不是解決方案。至少有可能讓它與 MySQL 一起工作嗎?
1 回答

慕尼黑8549860
TA貢獻(xiàn)1818條經(jīng)驗(yàn) 獲得超11個(gè)贊
Stmt.Query()有一個(gè)可變參數(shù):
func (s *Stmt) Query(args ...interface{}) (*Rows, error)
這意味著您可以使用省略號(hào)...將切片值作為可變參數(shù)的值傳遞,但該切片必須是 type []interface{},例如:
var args []interface{}
for _, v := range r.Form["type"] {
t, _ := strconv.Atoi(v)
args = append(args, t)
}
// ...
rows, err := stmt.Query(args...)
作為替代方案,您可以預(yù)先構(gòu)建 SQL 查詢并在不傳遞查詢參數(shù)的情況下執(zhí)行,例如,請(qǐng)參閱Postgres 中的 Go 和 IN 子句。
添加回答
舉報(bào)
0/150
提交
取消