栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

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

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

解析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示例。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/409651.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号