dongzhuang6417 2018-06-06 09:00
浏览 879
已采纳

如何将float32数组保存为来自gorm的双精度

I try save float32 in golang to db (postgresql). I use gorm. My Field in struct:

    Cluster [512]float32 `gorm:"column:cluster;type:float[]"`

When i save to db, log mode show me right sql, but write error:

converting argument $3 type: unsupported type [512]float32, a array

Сan anyone have an idea how to tell the postgres what to do? Thank you!

  • 写回答

1条回答 默认 最新

  • douba6365 2018-06-06 09:52
    关注

    I've encountered a problem like this. I suggest you make you own type for your array that implements

    type Valuer interface

    and

    type Scanner interface

    from database/sql package.

    Also you could try pq.Float64Array type instead of float slice (I know that is float64, but it is the only type they have) from github.com/lib/pq.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?