第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問(wèn)題,去搜搜看,總會(huì)有你想問(wèn)的

Golang MySQL使用IN運(yùn)算符查詢未定義數(shù)量的參數(shù)

Golang MySQL使用IN運(yùn)算符查詢未定義數(shù)量的參數(shù)

紅糖糍粑 2022-03-07 16:00:59
我正在嘗試使用帶有未定義參數(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 子句。


查看完整回答
反對(duì) 回復(fù) 2022-03-07
  • 1 回答
  • 0 關(guān)注
  • 303 瀏覽
慕課專欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)