1

为了简化代码,并防止一次又一次地传递类似的参数,我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

4

1 回答 1

0

在您的查询$2, $3...$N 中是作为额外参数传入的参数的索引,db.Exec()它们必须从$1(如果您使用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 ($1, $2, $3);`, func(u User) []interface{} {
    return []interface{}{u.Name, u.Username, u.Password}
})
于 2021-02-11T04:57:47.797 回答