将足够多的参数传递给 lib/pq
pass more than enough arguments to lib/pq
为了简化代码,防止重复传递相似的参数,我为下面的一些结构创建了一个方法Put
。
比如这里之所以没有使用UID
是因为UID
设置为自动增加值
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 (, , );`)
}
但是我得到以下错误
pq: could not determine data type of parameter
(SQL 驱动程序是 https://github.com/lib/pq)
在您的查询中,, ...$N
是作为额外参数传递给 db.Exec()
的参数的索引,它们必须从 </code> 开始(如果您使用 <code>database/sql
包)。
我认为在你的情况下你可以更改 Put
方法签名(添加 struct 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 (, , );`, func(u User) []interface{} {
return []interface{}{u.Name, u.Username, u.Password}
})
为了简化代码,防止重复传递相似的参数,我为下面的一些结构创建了一个方法Put
。
比如这里之所以没有使用UID
是因为UID
设置为自动增加值
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 (, , );`)
}
但是我得到以下错误
pq: could not determine data type of parameter
(SQL 驱动程序是 https://github.com/lib/pq)
在您的查询中,, ...$N
是作为额外参数传递给 db.Exec()
的参数的索引,它们必须从 </code> 开始(如果您使用 <code>database/sql
包)。
我认为在你的情况下你可以更改 Put
方法签名(添加 struct 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 (, , );`, func(u User) []interface{} {
return []interface{}{u.Name, u.Username, u.Password}
})