为了账号安全,请及时绑定邮箱和手机立即绑定

恐慌:sql:扫描中预期有 1 个目标参数,而不是 <number> golang、pq、sql

恐慌:sql:扫描中预期有 1 个目标参数,而不是 <number> golang、pq、sql

Go
千巷猫影 2021-12-07 17:05:39
我正在使用 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)恐慌:sql:扫描中预期有1个目标参数,而不是3个。根据行。Scan可以传递n个目标参数。这段代码有什么问题?
查看完整描述

1 回答

?
噜噜哒

TA贡献1784条经验 获得超7个赞

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


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

}


查看完整回答
反对 回复 2021-12-07
  • 1 回答
  • 0 关注
  • 163 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信