【问题标题】:panic: sql: expected 1 destination arguments in Scan, not <number> golang, pq, sql恐慌:sql:Scan 中预期的 1 个目标参数,而不是 <number> golang、pq、sql
【发布时间】:2016-01-31 18:36:57
【问题描述】:

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

【问题讨论】:

  • 您将三个参数传递给Scan()。格式字符串只需要一个。

标签: postgresql go


【解决方案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
}

【讨论】:

  • 是的,它在工作@MuffinTop。我的表中有很多数据->> 字段。能否请您分享一段代码如何使用“数据作为单个字段并使用 encoding/json 包解码结果”。
  • 非常感谢@MuffinTop :)
  • 只是为了通知你 json.Unmarshal 而不是 json.Decode。代码作为一种魅力。再次感谢
  • 这个解决方案看起来确实不错。但我无法实现它。我仍然遇到同样的错误。你可以在这里看到我的代码 - play.golang.org/p/x_P50Ode4QU。你知道我在做什么错吗?
  • @RahulSatal 如果您使用 Postgres JSONB 字段,此答案的详细信息仅与您的应用程序相关。通过将各个字段的地址传递给 Scan 来修复您的应用程序。
猜你喜欢
  • 2020-04-25
  • 2014-10-10
  • 1970-01-01
  • 1970-01-01
  • 2014-09-21
  • 2015-09-28
  • 2021-07-11
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多