一尘不染

恐慌:sql:扫描中应有1个目标参数,而不是 golang,pq,sql

go

我正在使用db.QueryRow获取数据。使用Postgresql创建的数据类型为jsonb的表。下面是golang中的代码

m := Message{}
err := db.QueryRow("SELECT data FROM message WHERE data->>'id'=$1", id).Scan(m.Id, m.Type, m.Title)

panic:sql:在Scan中应该有1个目标参数,而不是3。按行。Scan可以传递n个目标参数。此代码有什么问题?


阅读 233

收藏
2020-07-02

共1个答案

一尘不染

查询每行返回一个字段。该代码正在扫描三个。也许您想要这样的东西:

err := db.QueryRow("SELECT data->>'id', data->>'type', data->>'title' FROM message WHERE data->>'id'=$1", id).Scan(m.Id, m.Type, m.Title)

另外,将指针传递给值:

err := db.QueryRow("SELECT data->>'id', data->>'type', data->>'title' FROM message WHERE data->>'id'=$1", id).Scan(&m.Id, &m.Type, &m.Title)

另一个选择是将数据作为单个字段获取,并使用encoding / json包对结果进行解码。

var p []byte
err := db.QueryRow("SELECT data FROM message WHERE data->>'id'=$1", id).Scan(&p)
if err != nil {
    // handle error
}
var m Message
err := json.Unmarshal(p, &m)
if err != nil {
    // handle error
}
2020-07-02