为了简化代码,并防止一次又一次地传递类似的参数,我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 ($2, $3, $4);`)
}
但我得到下面的错误
pq: could not determine data type of parameter $1
(SQL 驱动是https://github.com/lib/pq)