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

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

將足夠多的參數(shù)傳遞給 lib/pq

將足夠多的參數(shù)傳遞給 lib/pq

Go
SMILET 2022-08-09 16:38:43
為了簡(jiǎn)化代碼,并防止一次又一次地傳遞類(lèi)似的參數(shù),我為一些結(jié)構(gòu)創(chuàng)建了一個(gè)方法,如下所示。例如,此處不使用的原因是因?yàn)楸辉O(shè)置為自動(dòng)增加值。PutUIDUIDtype User struct {    UID      int    Name     string    Username string    Password string}func (user *User) Put(db *sql.DB, query string) (sql.Result, error) {    return db.Exec(query, u.UID, u.Name, u.Username, u.Password)}func main() {    db := ...    u := &User{...}    u.Put(db, `INSERT INTO user(name, username, password) VALUES ($2, $3, $4);`)}但是我得到下面的錯(cuò)誤pq: could not determine data type of parameter $1
查看完整描述

1 回答

?
慕慕森

TA貢獻(xiàn)1856條經(jīng)驗(yàn) 獲得超17個(gè)贊

在查詢中,是作為額外參數(shù)傳入的參數(shù)的索引,并且它們必須從(如果使用包)開(kāi)始。$2, $3...$Ndb.Exec()$1database/sql


我認(rèn)為在您的情況下,您可以更改方法簽名(添加Putstruct values extractor)


func (user *User) Put(db *sql.DB, query string, extractor func(user User)[]interface{}) (sql.Result, error) {

    return db.Exec(query, extractor(*user)...)

}

并使用一個(gè)像


u.Put(db,`INSERT INTO user(name, username, password) VALUES ($1, $2, $3);`, func(u User) []interface{} {

    return []interface{}{u.Name, u.Username, u.Password}

})


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

添加回答

舉報(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)