登录
首页 >  Golang >  Go问答

将非结构化 JSON BYTEA 扫描到映射字符串中

来源:stackoverflow

时间:2024-04-10 09:18:37 362浏览 收藏

学习知识要善于思考,思考,再思考!今天golang学习网小编就给大家带来《将非结构化 JSON BYTEA 扫描到映射字符串中》,以下内容主要包含等知识点,如果你正在学习或准备学习Golang,就都不要错过本文啦~让我们一起来看看吧,能帮助到你就更好了!

问题内容

这似乎是一个常见问题,可能已经发布在某个地方,但我找不到任何讨论它的线程,所以问题是:

我有一个 postgres 表,存储 bytea 类型的列。

create table foo (
  id         varchar primary key,
  json_data  bytea
)

json_data 实际上只是存储为 bytea 的 json(我知道这并不理想)。它是非结构化的,但保证是 string -> string json。

当我查询此表时,我需要将查询 select * from foo where id = $1 扫描到以下结构中:

type JSONData map[string]string

type Foo struct {
  ID    string   `db:"id"`
  Data  JSONData `db:"json_data"`
}

我正在使用 sqlx 的 get 方法。当我执行查询时,收到错误消息 sql: scan error on column index 1, name "json_data": unsupported scan, saving driver.value type []uint8 into type *foo.jsondata

显然,扫描仪在将 json bytea 扫描到地图时遇到问题。我可以实现我自己的扫描仪并在 json_data 列上调用我的自定义扫描仪,但我想知道是否有更好的方法来执行此操作。我的 jsondata 类型可以实现现有接口来自动执行此操作吗?


解决方案


根据 @ilovereflection 的建议,在 *jsondata 上实现 Scanner 接口是有效的。下面是实际的实现:

func (j *JSONData) Scan(src interface{}) error {
    b, ok := src.([]byte)
    if !ok {
        return errors.New("invalid data type")
    }

    return json.Unmarshal(b, j)
}

以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于Golang的相关知识,也可关注golang学习网公众号。

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>