首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >向lib/pq传递足够多的参数

向lib/pq传递足够多的参数
EN

Stack Overflow用户
提问于 2021-02-11 03:27:01
回答 1查看 142关注 0票数 1

为了简化代码,防止重复传递类似的参数,我为一些结构创建了一个方法Put,如下所示。

例如,此处不使用UID的原因是UID被设置为自动增加值。

代码语言:javascript
复制
type 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);`)
}

但是我得到了下面的错误

代码语言:javascript
复制
pq: could not determine data type of parameter $1

(SQL驱动程序是https://github.com/lib/pq)

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-02-11 04:57:47

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

我认为在您的情况下,您可以更改Put方法签名(添加struct values extractor)

代码语言:javascript
复制
func (user *User) Put(db *sql.DB, query string, extractor func(user User)[]interface{}) (sql.Result, error) {
    return db.Exec(query, extractor(*user)...)
}

然后用一个类似的

代码语言:javascript
复制
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}
})
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/66148359

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档