為了簡(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}
})
- 1 回答
- 0 關(guān)注
- 113 瀏覽
添加回答
舉報(bào)
0/150
提交
取消