亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

當執行mysql更新sql語句時,如何在go中同時綁定多變量和切片變量?

當執行mysql更新sql語句時,如何在go中同時綁定多變量和切片變量?

Go
楊__羊羊 2023-07-26 19:54:18
corresponding parameter is non-variadic我有一些字符串變量和一個切片變量作為 golang 中的 SQL 參數,但是當我嘗試執行時返回錯誤。那么在這種情況下我該如何綁定這些變量呢?mysql 連接器:go-sql-driver/mysql假代碼:func UpdateTblNm (foo, baz string, bar int, pars []string) error {    stmt:= `update tbl_nm set foo=?, bar=? where baz=? and par in (?`+ strings.Repeat(", ?", len(pars)-1) + `)`    if _, err := tx.Exec(stmt, foo, bar, baz, pars...); err!=nil {        return err    }    ... ...}我是 gopher 的新人..希望你的幫助,謝謝
查看完整描述

1 回答

?
慕標5832272

TA貢獻1966條經驗 獲得超4個贊

由于您有固定數量的參數和一個可變參數,因此您必須將它們全部收集到一個數組中,然后傳遞它們,因為 go 可變參數無法處理您想要執行的操作:


args:=[]interface{}{foo,baz,bar}

for _,x:=range pars {

  args=append(args,x)

}

tx.Exec(stmt,args...)


查看完整回答
反對 回復 2023-07-26
  • 1 回答
  • 0 關注
  • 141 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號