0

样本:

{
  "id": 1
  "data": {"1": 2}
}

结构定义:

type Item struct {
  id int `json:"id"`
  data interface{} `json:"data"`
}

我需要从 http 帖子中解析有效负载,所以我使用interface{}fordatajson.Unmarshal()成功的,但是 gorm 在调用时会产生错误db.Create(item)

(sql: converting Exec argument #5's type: unsupported type map[string]interface {}, a map)

相反,我从 更改interface{}string,调用json.Unmarshal()解析 json POST 有效负载会产生错误。

unmarshal type error: expected=string, got=object

基本上,一个需要interface{},一个需要string

有人遇到过这个吗?

4

1 回答 1

1

解决方案是定义一个实现sql.Valuersql.Scanner和接口json.Marshaler的自定义类型。json.Unmarshaler我的实现示例:

type Data string

func (t *Data) MarshalJSON() ([]byte, error) {
    return []byte(*t), nil
}

func (t *Data) UnmarshalJSON(data []byte) error {
    *t = Data(data)
    return nil
}

func (t Data) Value() (driver.Value, error) {
    return string(t), nil
}

func (t *Data) Scan(src interface{}) error {
    s, ok := src.([]byte)
    if !ok {
        return nil
    }
    *t = Data(s)
    return nil
}

// Data implements the below interfaces to satisfy both
// json parser and sql parser
var _ json.Marshaler = (*Data)(nil)
var _ json.Unmarshaler = (*Data)(nil)
var _ sql.Scanner = (*Data)(nil)
var _ driver.Valuer = (*Data)(nil)
于 2016-12-15T03:53:55.840 回答