解析PostgreSQL TIMESTAMP类型的值时出现问题

解析PostgreSQL TIMESTAMP类型的值时出现问题,第1张

解析PostgreSQL TIMESTAMP类型的值时出现问题

该错误已说明出了什么问题:

时间“” 2019-01-01 00:00:00“”解析为“” 2006-01-02T15:04:05Z07:00“”:无法将“
00:00:00”“解析为” T“

您正在传递,

"2019-01-0100:00:00"
而它期望使用不同的时间格式,即RFC3339(UnmarshalJSON的默认值)。

为了解决这个问题,您要么希望以期望的格式传递时间,要么像这样

"2019-01-01T00:00:00Z00:00"
定义自己的类型
CustomTime

const timeFormat = "2006-01-02 15:04:05"type CustomTime time.Timefunc (ct *CustomTime) UnmarshalJSON(data []byte) error {    newTime, err := time.Parse(timeFormat, strings.Trim(string(data), """))    if err != nil {        return err    }    *ct = CustomTime(newTime)    return nil}func (ct *CustomTime) MarshalJSON() ([]byte, error) {    return []byte(fmt.Sprintf("%q", time.Time(*ct).Format(timeFormat))), nil}

小心,您可能还需要实现

Valuer
Scanner
接口,以便在数据库中进行解析时,如下所示:

func (ct CustomTime) Value() (driver.Value, error) {    return time.Time(ct), nil}func (ct *CustomTime) Scan(src interface{}) error {    if val, ok := src.(time.Time); ok {        *ct = CustomTime(val)    } else {        return errors.New("time Scanner passed a non-time object")    }    return nil}

转到Playground示例。



欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/zaji/5019999.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-11-15
下一篇2022-11-14

发表评论

登录后才能评论

评论列表(0条)

    保存