为了账号安全,请及时绑定邮箱和手机立即绑定

将足够多的参数传递给 lib/pq

将足够多的参数传递给 lib/pq

Go
SMILET 2022-08-09 16:38:43
为了简化代码,并防止一次又一次地传递类似的参数,我为一些结构创建了一个方法,如下所示。例如,此处不使用的原因是因为被设置为自动增加值。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);`)}但是我得到下面的错误pq: could not determine data type of parameter $1
查看完整描述

1 回答

?
慕慕森

TA贡献1856条经验 获得超17个赞

在查询中,是作为额外参数传入的参数的索引,并且它们必须从(如果使用包)开始。$2, $3...$Ndb.Exec()$1database/sql


我认为在您的情况下,您可以更改方法签名(添加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)...)

}

并使用一个像


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}

})


查看完整回答
反对 回复 2022-08-09
  • 1 回答
  • 0 关注
  • 96 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信