gpt4 book ai didi

postgresql - panic : sql: expected 1 destination arguments in Scan, 不是 golang、pq、sql

转载 作者:IT王子 更新时间:2023-10-29 00:55:55 25 4
gpt4 key购买 nike

我正在使用 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:扫描中预期有 1 个目标参数,而不是 3 个。根据 row.Scan可以传递 n 个目标参数。这段代码有什么问题?

最佳答案

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

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
}

关于postgresql - panic : sql: expected 1 destination arguments in Scan, 不是 <number> golang、pq、sql,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35117714/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com