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

标签 postgresql go 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 ($2, $3, $4);`)
}
但我得到下面的错误
pq: could not determine data type of parameter $1
(SQL驱动程序为https://github.com/lib/pq)

最佳答案

在查询中$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}
})

关于postgresql - 将足够多的参数传递给lib/pq,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/66148359/

相关文章:

excel - Golang Excelize : how to set cell value with row nmber and column number

Go迁移不会创建外键

linux - 如何安装查找/内部位置

python - psycopg2.ProgrammingError : column cons. consrc 不存在

sql - 连接和计算来自不同表的行

postgresql - 我怎么知道 Postgres 表的统计信息是否是最新的?

postgresql - Golang postgres 提交未知命令错误?

postgresql - Go-Gorm 是否支持在 PostgreSQL 中使用自动递增 ID 插入分区表?

go - 调用 db.Ping() 时的无限循环

ruby-on-rails - 推送到 Heroku 后无法连接到 PostgreSQL 数据库